在手机端浏览网页时,经常使用一个功能,当我们浏览京东或者淘宝时,页面滑动到底部,我们看到数据自动加载到列表。之前并不知道这些功能是怎么实现的,于是自己在PC浏览器上模拟实现这样的功能。先看看浏览效果:

当滚动条滚动到页面底部时,提示“正在加载…”。

当页面已经加载了所有数据后,滚动到页面底部会提示“数据已加载到底了”:

实现数据无限加载的过程大致如下:

1.滚动条滚动到页面底部。

2.触发ajax加载,把请求返回的数据加载到列表后面。

如何判断滚动条是否滚动到页面底部?我们可以设置一个规则:当滚动条的滚动高度和整个文档高度相差不到20像素,则认为滚动条滚动到页面底部了:

文档高度 - 视口高度 - 滚动条滚动高度 < 20

要通过代码实现这样的判断,我们必须要了解上面的这些高度通过哪些代码获取?可以参考我之前写的一篇“HTML元素坐标定位,这些知识点得掌握”。

上面的判断,我封装了一个方法:

//检测滚动条是否滚动到页面底部function isScrollToPageBottom(){//文档高度var documentHeight = document.documentElement.offsetHeight;var viewPortHeight = getViewportSize().h;var scrollHeight = window.pageYOffset ||document.documentElement.scrollTop ||document.body.scrollTop || 0;return documentHeight - viewPortHeight - scrollHeight < 20;}

判断有了,我们就可以开启一个定时器,900毫秒监测一次,如果isScrollToPageBottom()返回true则调用ajax请求数据,如果返回false则通过900毫秒之后再监测。

下面是核心代码实现:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>无限分页</title><link rel="stylesheet" href="assets/css/index.css"/>
</head>
<body>
<div class="l-page"><ul id="list" class="list"></ul>
</div>
<script src="//cdn.bootcss.com/jquery/3.1.0/jquery.min.js"></script>
<script src="js/jquery.mockjax.js"></script>
<script type="text/javascript" src="js/dataMock.js"></script>
<script type="text/javascript">//作为一个对象的w和h属性返回视口的尺寸function getViewportSize(w){//使用指定的窗口, 如果不带参数则使用当前窗口
        w = w || window;//除了IE8及更早的版本以外,其他浏览器都能用if(w.innerWidth != null)return {w: w.innerWidth, h: w.innerHeight};//对标准模式下的IE(或任意浏览器)var d = w.document;if(document.compatMode == "CSS1Compat")return {w: d.documentElement.clientWidth, h: d.documentElement.clientHeight};//对怪异模式下的浏览器return {w: d.body.clientWidth, h: d.body.clientHeight};}//检测滚动条是否滚动到页面底部function isScrollToPageBottom(){//文档高度var documentHeight = document.documentElement.offsetHeight;var viewPortHeight = getViewportSize().h;var scrollHeight = window.pageYOffset ||document.documentElement.scrollTop ||document.body.scrollTop || 0;return documentHeight - viewPortHeight - scrollHeight < 20;}//商品模板function getGoodsTemplate(goods){return "<li>" +"<div class='pic-wrap leftFloat'>" +"<img src='" + goods.pic + "'>" +"</div>" +"<div class='info-wrap leftFloat'>" +"<div class='info-name'><span>" + goods.name + "</span></div>" +"<div class='info-address'><span>" + goods.address +"</span></div>" +"<div class='info-bottom'>" +"<div class='info-price leftFloat'><span>¥" + goods.price + "</span></div>" +"<div class='info-star leftFloat'><span>" + goods.star + "人推荐</span></div>" +"<div class='info-more leftFloat'><span>更多信息</span></div>" +"</div>" +"</div>" +"</li>";}//初始化的时候默给list加载100条数据
    $.ajax("http://localhost:8800/loadData?sessionId=" + (+ new Date)).done(function(result){if(result.status){var html = "";result.data.forEach(function(goods){html += getGoodsTemplate(goods);});$("#list").append(html);}});//加载数据function loadDataDynamic(){//先显示正在加载中if( $("#loadingLi").length === 0)$("#list").append("<li id='loadingLi' class='loading'>正在加载...</li>");else{$("#loadingLi").text("正在加载...").removeClass("space");}var loadingLi = document.getElementById("loadingLi");loadingLi.scrollIntoView();//加载数据,数据加载完成后需要移除加载提示var hasData = false, msg = "";$.ajax("http://localhost:8800/loadData?sessionId=" + (+ new Date)).done(function(result){if(result.status){if(result.data.length > 0){hasData = true;var html = "";result.data.forEach(function(goods){html += getGoodsTemplate(goods);});$("#list").append(html);}else{msg = "数据已加载到底了"}}$("#list").append(loadingLi);}).fail(function(){msg = "数据加载失败!";}).always(function(){!hasData && setTimeout(function(){$(document.body).scrollTop(document.body.scrollTop -40);}, 500);msg && $("#loadingLi").text(msg);//重新监听滚动
            setTimeout(watchScroll, 900);});}//如果滚动条滚动到页面底部,需要加载新的数据,并且显示加载提示function watchScroll(){if(!isScrollToPageBottom()){setTimeout( arguments.callee, 900);return;            }loadDataDynamic();}//开始检测滚动条
    watchScroll();
</script>
</body>
</html>

demo中ajax请求我是通过jquery-mockjax模拟的数据。代码如下:

/*** 模拟接口.*/
var i = 0, len = 200, addresses = ["四川", "北京", "上海", "广州", "深圳", "甘肃", "云南", "浙江", "青海", "贵州"];function getData(){var size = Math.min(i + 50, len), arr = [];for(; i < size; i++){arr.push({name: "苹果" + (i % 10 + 1),pic: "assets/images/iphone" + (i % 10 + 1) + ".jpg",price: parseInt(Math.random() * 10000),star: parseInt(Math.random() * 1000),address: addresses[i % 10]})}return arr;
}$.mockjax({url: 'http://localhost:8800/loadData*',responseTime: 1000,response: function(settings){this.responseText = {status: true,data: getData()}}
});

整个完整的demo我已上传到github上:

https://github.com/heavis/pageLoader

在线演示:

https://heavis.github.io/pageLoader/index.html

如果本篇内容对大家有帮助,请点击页面右下角的关注。如果觉得不好,也欢迎拍砖。你们的评价就是博主的动力!下篇内容,敬请期待!

JS实现-页面数据无限加载相关推荐

  1. js后退页面不重新加载_快应用:支持加载单独JS文件的规范思考

    当前快应用的项目中,支持加载其它JS文件(通过:require('./foo.js')),然后通过webpack工具处理依赖,最终完成页面JS的构建,其中页面JS包含了引入的所有JS内容: 本文讨论的 ...

  2. js刷新页面得重新加载和页面的刷新

    1.reload 方法,该方法强迫浏览器刷新当前页面.  语法:location.reload([bForceGet])  参数: bForceGet, 可选参数, 默认为 false,从客户端缓存里 ...

  3. [置顶]       Javascript js中页面的重新加载

    用JavaScript刷新上级页面和当前页面 <script type="text/javascript"> //刷新上级页面 //window.parent.main ...

  4. js判断页面是首次加载还是刷新

    1:利用window.name属性在页面刷新时不会重置判断(在改属性空置的情况下可使用) if(window.name == ""){console.log("首次被加载 ...

  5. Vue.js 开发实践:实现精巧的无限加载与分页功能

    小编推荐:Fundebug专注于JavaScript.微信小程序.微信小游戏,Node.js和Java实时BUG监控.真的是一个很好用的bug监控费服务,众多大佬公司都在使用. 本篇文章是一篇Vue. ...

  6. js如何将数据放在一个内置窗口里面_Java 爬虫遇上数据异步加载,试试这两种办法!...

    这是 Java 爬虫系列博文的第三篇,在上一篇 Java 爬虫遇到需要登录的网站,该怎么办? 中,我们简单的讲解了爬虫时遇到登录问题的解决办法,在这篇文章中我们一起来聊一聊爬虫时遇到数据异步加载的问题 ...

  7. jq分页 不刷新页面_滑动无限加载和分页哪个对搜索引擎更友好呢?

    滑动无限加载和分页哪个对搜索引擎更友好呢? 最近,做搜索引擎优化的工作,发现谷歌只搜索了第一次加载更多前的页面,做这个功能前就有这个担心,结果还是发生了,加载更多后的页面搜索不到. 对搜索引擎优化工作 ...

  8. js页面中实现加载更多功能

    js页面中实现加载更多功能 分页-如何实现加载更多功能,目前的在很多网站上使用的加载更多功能中,使用最多的是iscroll.js实现的上拉加载更多.下拉刷新功能.但是iscroll.js本身并没有集成 ...

  9. ajax瀑布流插件,jQuery瀑布流无限加载插件:jquery.falless.js

    慌慌张张,匆匆忙忙,为何生活总是这样? 难道说,我的理想,就是这样度过一生的时光?........... 真的是一年一年飞逝而去,而人的一生,又有几个一年? 第一个四年即将结束,得到了什么?又失去了什 ...

最新文章

  1. 检查是否已使用jQuery选中复选框
  2. IE8抢先尝试——色眼窥观版(多图)
  3. Intel Realsense USB设备的插入检测机制
  4. 爬虫实战:使用Selenium爬取京东宝贝信息
  5. ROS:Nvidia Jetson TK1平台安装使用ROS
  6. ts获取服务器数据_基于Nginx的媒体服务器技术-线上公开课
  7. html cookie传参,页面间固定参数,通过cookie传值的实现方法
  8. 基于稀疏矩阵的k近邻(KNN)实现
  9. win10连接VMWare下的Ubutun系统进行FPT文件传输
  10. 事情没有想象中那么难--JX官网首页3D粒子效果
  11. 应用phpexcel导出excel文件后打不开的问题解决方法
  12. 相机模型与标定(十)--RANSAC算法
  13. python函数参数用法_Python:函数参数类型及其用法
  14. https默认端口_Java企业信息化平台O2OA如何配置服务器来启用HTTPS(SSL)
  15. JMeter脚本录制-快速上手篇
  16. Linux运维学习路线
  17. [CISCN2019 华东南赛区]Web11
  18. 数据挖掘经典十大算法_对基本概念的理解
  19. 《如何让你爱的人爱上你》第四部分:等价原则
  20. 免费在线思维导图网站,这么好用一定要收藏

热门文章

  1. mvc ajax_返回数据
  2. java泛型的几个例子
  3. ASP.NET缓存 Cache之数据缓存
  4. 微软虚拟学院开学了!
  5. CSS有效的编写代码
  6. hi3516中home中的ko
  7. vue 热更新无反应_不吹不黑谈谈 vue 的 SFC 和 template
  8. feign调用多个服务_Spring Cloud多个微服务之间调用代码实例
  9. 适合初学者的Python小游戏开发,不仅有趣还能巩固自己所学知识
  10. kali linux安装ftp服务,CentOS7安装和配置FTP