100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > js如何实现页面的滚动条下拉时加载更多(code)

js如何实现页面的滚动条下拉时加载更多(code)

时间:2022-10-09 18:42:36

相关推荐

js如何实现页面的滚动条下拉时加载更多(code)

web前端|js教程

javascript,jquery

web前端-js教程

本篇文章给大家带来的内容是关于js如何实现页面的滚动条下拉时加载更多(附代码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

砍价源码,Ubuntu蓝牙无法打开,php抓取爬虫文件,php tarit,SEO怎么注册lzw

在手机上,数据列表的分页都是下拉到底部的时候会加载更多,但是,去年三月份的时候遇到了客户要求web页面也要下拉加载更多的需求,于是按照web页面在滚动条下拉时加载更多内容(个人项目经验)文中的代码实现了这个下拉加载,很简单的,代码如下:

微信公众号页面源码,怎样给vscode文件改名,ubuntu搭建srs,给tomcat添加jar,亚马逊爬虫平台,php编程大讲堂,台州seo网络推广哪里好,windows风格网站,仿天猫电子模板lzw

var totalPages;//总页数var pageno = 0;//当前页数$(function(){ $(window).scroll(function() { var scrollTop = $(this).scrollTop(),scrollHeight = $(document).height(),windowHeight = $(this).height(); var positionValue = (scrollTop + windowHeight) - scrollHeight; if (positionValue == 0) { //do something if (pageno < totalPages - 1) {pageno++;doSomething(pageno); } else {alert(没有更多了); } } });); function doSomething(pageno) { var url = "*******";//分页列表的接口 var data = {size: 5,start: pageno, }; $.getJSON(url, data, function (rtn) { });}

但是,今天测试人员发现,当浏览器缩放了或者屏幕显示设置缩放时,就不能下拉加载了。时隔一年多,真是惊人@_@

班级抽奖软件源码,vscode 重复行删除,ubuntu占用网卡,线程中断tomcat,sqlite 指定数据库,爬虫与算法的关系是什么,php redis秒杀,山东长沙seo优化渠道,dede制作的网站挂马,html个人网页模板下载,自然景观网站模板lzw

经过调试,发现是有缩放时positionValue的值就无法等于0了,没法继续加载更多了,这时看到一篇文章下拉加载更多DEMO(js实现)中讲到:

如果等滚动条拉到底部时再加载,会影响用户体验。因为一般动态加载的时候都需要向服务端请求资源,这时需要时间。一个更佳的方式是,当滚动条距离底部一定距离(C)时,就动态加载更多,向服务端请求资源。也就是预加载,预读取。公式如下

this.scrollHeight – C == $(this).scrollTop() + $(this).height()

看完后收到启发,于是将positionValue的值设为大于等于-10,这里的10也就是滚动条距离底部一定距离(C)的值。

果然,没问题了,有缩放时也可以正常实现下拉加载。

于是,记录下来,分享给大家,共勉。

另外提醒一点,$(window).scroll(function()监听滚动事件不执行这个问题中的采纳答案提到:

html,body的高度样式如果设置为100%,$(window).scroll方法将检测不到正确的滚出高度(0),导致滚动监听事件失效,设置html,body{ height:auto }可以解决。

代码

var totalPages;//总页数var pageno = 0;//当前页数var C = 10;//滚动条距离底部的距离$(function(){ $(window).scroll(function() { var scrollTop = $(this).scrollTop(),scrollHeight = $(document).height(),windowHeight = $(this).height(); var positionValue = (scrollTop + windowHeight) - scrollHeight; if (positionValue >= -C) { //do something if (pageno < totalPages - 1) {pageno++;doSomething(pageno); } else {alert(没有更多了); } } });); function doSomething(pageno) { var url = "*******";//分页列表的接口 var data = {size: 5,start: pageno, }; $.getJSON(url, data, function (rtn) { });}

jQuery向下滚动即时加载内容实现的瀑布流效果,jquery向下滚动

js实现滚动条滚动到页面底部继续加载_javascript技巧

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。