新闻列表懒加载

原理:

和图片懒加载类似,都是判断临界条件。
新闻列表懒加载是通过在列表后面设置一个隐藏元素span(或其他)

判断这个元素出现在可视窗口里面,那么发送请求

下面是具体步骤:

1,隐藏标准元素span

2,判断元素span在不在可是窗口内


开始的时候页面上只有一两条元素,那么就需要在没有滚动条的情况下自动加载(自动发送请求),让数据充满这个可视区


3,当页面自动加载一定量的数据后,span 元素被挤到窗口的下面,不可见的地方,不能通过自动加载数据发送请求了,这个时候就需要通过监听窗口滚动条的滚动事件判断span元素刚好在可视区,那么请求加载数据

注意点:

1,2步中打开页面的时候,自动加载数据的代码写法:

自动加载数据的方法,首先执行一次ajax请求,然后通过下面图片的方法


2,如果滚动过快,那么会多次请求同一条数据(类似数据还没有发生到浏览器并且还没有显示成功,再次点击加载更多按钮)

解决办法:设置状态锁


3,最后一次请求的新闻数据为 ret=[] 一个空数组,怎么让请求停止,同样设置状态锁


github代码
若愚老师代码
4,移动web端的懒加载滚动事件前提

      $(window).on("scroll",function(){
           var $load = $(".loading-more").eq(0)
            //滚动高度
            var scrollTop=$(window).scrollTop(),
            //窗口高度+滚动高度(元素刚好要进入窗口)
             s_rTop=$(window).height()+scrollTop,
            //元素到文档顶部高度
             offsetTop= $load.offset().top,
            //元素底部刚好出窗口上边(元素刚好要离开窗口)
             e_rTop=offsetTop+$load.outerHeight()

            if(offsetTop<s_rTop&&scrollTop<e_rTop){
                console.log("1")  //加载数据
            }else{
                return false
            }
       })
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 136,527评论 19 139
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,108评论 1 92
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 178,856评论 25 709
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 15,131评论 4 61
  • 一、SDWebImage介绍 1、在项目的开发过程中,我们经常会用到异步加载图片的功能,先从网络上异步下载图片,然...
    天地不仁以万物为刍狗阅读 653评论 0 2

友情链接更多精彩内容