滚动条滚动到页面底部继续加载的处理实例
来源:互联网 发布:淘宝主图制作 编辑:程序博客网 时间:2024/06/05 14:37
原理很简单,就是为window添加一个scroll事件,浏览器每次触发scroll事件时判断是否滚动到了浏览器底部,如果到了底部则加载新数据。关键是计算滚动条是否滚动到了浏览器底部,算法如下
滚动条卷起来的高度 + 窗口高度 > 文档的总高度 + 50/*我这里将滚动响应区域高度取50px*/;如果这个判断为true则表示滚动条滚动到了底部。
实例
<style type="text/css"> html,body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, button, textarea, p, blockquote, th, td{ margin: 0; padding:0; } *{ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; } .waterfllow-loading{ z-index: 2000; display:none; } .waterfllow-loading.active{ display:block; } .waterfllow-loading img.loading-progress{ position: fixed; /*设置等待条水平居于窗口正中*/ margin-left: auto; margin-right: auto; left: 0; right: 0; /*不能设置margin-top:auto和margin-bottom:auto否则IE下bottom就不顶用了*/ bottom: 30px; } </style> <div class="waterfllow-loading"> <img class="loading-progress" src="busy.gif"> </div> <script type="text/javascript"> //图片查询中正对浏览器主页面滚动事件处理(瀑布流)。只能使用window方式绑定,使用document方式不起作用 $(window).on('scroll',function(){ if(scrollTop() + windowHeight() >= (documentHeight() - 50/*滚动响应区域高度取50px*/)){ waterallowData(); } }); function waterallowData(){ $('.waterfllow-loading').addClass('active'); /*$.ajax({ url:url, type:"post", data: params, success:function(data,textStatus,jQXHR){ //添加数据 ... //隐藏加载条 $('.waterfllow-loading.active').removeClass('active'); } });*/ }
获取页面顶部被卷起来的高度函数
//获取页面顶部被卷起来的高度 function scrollTop(){ return Math.max( //chrome document.body.scrollTop, //firefox/IE document.documentElement.scrollTop); }
chrome浏览器和Firefox/IE对滚动条是属于body还是html理解不同导致处理不同。
获取页面文档的总高度
//获取页面文档的总高度 function documentHeight(){ //现代浏览器(IE9+和其他浏览器)和IE8的document.body.scrollHeight和document.documentElement.scrollHeight都可以 return Math.max(document.body.scrollHeight,document.documentElement.scrollHeight); }
这个算法和jQuery计算文档高度的方法一致。
获取页面浏览器视口的高度
function windowHeight(){ return (document.compatMode == "CSS1Compat")? document.documentElement.clientHeight: document.body.clientHeight; }
这里需要说明的是document.compatMode这个东东。很陌生,一般情况貌似没有遇到过。
document.compatMode有两个取值"BackCompat"和"CSS1Compat"。官方解释是BackCompat:标准兼容模式关闭。CSS1Compat:标准兼容模式开启。
IE对盒模型的渲染在 Standards Mode和Quirks Mode是有很大差别的,在Standards Mode下对于盒模型的解释和其他的标准浏览器是一样,但在Quirks Mode模式下则有很大差别,而在不声明Doctype的情况下,IE默认又是Quirks Mode。
举个例子说明两种模式之间的差别有多大。
当document.compatMode等于"BackCompat"时,浏览器客户区宽度是document.body.clientWidth;
当document.compatMode等于CSS1Compat时,浏览器客户区宽度是document.documentElement.clientWidth。
还有其他属性类似。这里不说了,但是我们可以预见两种模式导致IE渲染的基石都更改了,可想而知构建出来的建筑物差别当有多大。
所以请为每一个页面声明Doctype不仅仅是一个好习惯,而且是一个必要的处理。Quirks Mode可以进垃圾堆了。
好了下面附上完整的代码,有一个小例子(没有后台刷数据,只是显示等待条)
<!DOCTYPE html><html lang="ch-cn"> <head> <meta charset="utf-8"> <script type="text/javascript" src='jquery-1.9.1.js'></script> <style type="text/css"> html,body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, legend, input, button, textarea, p, blockquote, th, td{ margin: 0; padding:0; } *{ -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; } .waterfllow-loading{ z-index: 2000; display:none; } .waterfllow-loading.active{ display:block; } .waterfllow-loading img.loading-progress{ position: fixed; /*设置等待条水平居于窗口正中*/ margin-left: auto; margin-right: auto; left: 0; right: 0; /*不能设置margin-top:auto和margin-bottom:auto否则IE下bottom就不顶用了*/ bottom: 30px; } </style> </head> <body style="background:#ff0;height:1000px;"> <div class="waterfllow-loading"> <img class="loading-progress" src="busy.gif"> </div> </body> <script type="text/javascript"> //获取页面顶部被卷起来的高度 function scrollTop(){ return Math.max( //chrome document.body.scrollTop, //firefox/IE document.documentElement.scrollTop); } //获取页面文档的总高度 function documentHeight(){ //现代浏览器(IE9+和其他浏览器)和IE8的document.body.scrollHeight和document.documentElement.scrollHeight都可以 return Math.max(document.body.scrollHeight,document.documentElement.scrollHeight); } //获取页面浏览器视口的高度 function windowHeight(){ //document.compatMode有两个取值。BackCompat:标准兼容模式关闭。CSS1Compat:标准兼容模式开启。 return (document.compatMode == "CSS1Compat")? document.documentElement.clientHeight: document.body.clientHeight; } </script> <script type="text/javascript"> //图片查询中正对浏览器主页面滚动事件处理(瀑布流)。只能使用window方式绑定,使用document方式不起作用 $(window).on('scroll',function(){ if(scrollTop() + windowHeight() >= (documentHeight() - 50/*滚动响应区域高度取50px*/)){ waterallowData(); } }); function waterallowData(){ $('.waterfllow-loading').addClass('active'); /*$.ajax({ url:url, type:"post", data: params, success:function(data,textStatus,jQXHR){ //添加数据 ... //隐藏加载条 $('.waterfllow-loading.active').removeClass('active'); } });*/ } </script> </html>
里面的加载条图片为
如果觉得本文不错,请点击右下方【推荐】!
- 滚动条滚动到页面底部继续加载的处理实例
- js 下拉底部加载|滑轮滚动到页面底部ajax加载数据的实例
- android ListView监听滚动条滚动到底部时继续加载
- android ListView监听滚动条滚动到底部时继续加载
- android ListView监听滚动条滚动到底部时继续加载
- javscript实现滚动条滚动到页面底部自动加载增加页面内容
- 滚动条到底部自动加载
- 滚动条到底部,自动加载数据
- python selenium 爬虫页面滚动条滚动到页面底部
- python selenium 爬虫页面滚动条滚动到页面底部
- jq判断滚动条到页面底部
- 页面滚动到底部,悬浮条固定到页面底部。
- 滚动条到底部时自己加载新的内容
- 滚动条到底部
- 页面滚动到底部自动加载
- 阻止在div上滚动滚动条,到底部和顶部带动整个页面的滚动条
- JQuery实现浏览器的滚动条滚动到底部后加载数据
- JQuery实现浏览器的滚动条滚动到底部后加载数据
- 《Android开发艺术探索》15章Android性能优化
- Android studio 查看签名文件MD5,SHA1
- 多iframe使用tab标签方式添加、删除、切换的处理实例
- Android内存优化之OOM
- html/css基础篇——html代码编写过程中的几个警惕点
- 滚动条滚动到页面底部继续加载的处理实例
- input中的disabled、readonly和hidden别误用
- OpenCV学习笔记_对图像设置ROI
- placeholder的兼容处理(jQuery下)
- 将表单序列化类型的数据转化成对象的处理(允许对象中包含对象)
- 丢失了文件localhost.localdomain.pid和mysql.sock怎么办?
- 多个ajax请求下等待条显示和隐藏的简单处理
- 弹出框优化实例(alert和confirm)
- 基于jQuery的一个简单的图片查看器