jquery浏览器滚动加载技术实现方案


Posted in Javascript onJune 03, 2014

要知道,数据量增加很频繁时,要通过定位页码来找到目标数据似乎并没有什么意义。我觉得用户体验成熟的WEB应用程序应当引导用户使用TAG或搜索等功能来找到目标数据。至于浏览数据,尤其是浏览最新的数据,利用浏览器滚动条来加载,是很好的尝试……

我试着用jquery来实现这个功能。先要得到滚动条的总长属性值:scrollHeight,还有滚动条当前位置属性值:scrollTop。然后通过计算,若当前值位于总长值三分之二时加载新数据。假设DOM上有一个元素为<div id=”mypage”></div>,该元素overflow样式为scroll,也就是元素中的内容溢出元素指定高度时启用滚动条。利用jquery的load方法为元素加载一个已经存在的文件,我假设它是table.html。这个文件的内容可以是足以使浏览器滚屏的一张数据表。

<script type=”text/javascript” src=”jquery.js“>//加载jquery库</script>
<script type=”text/javascript”> gh
var hght=0;//初始化滚动条总长
var top=0;//初始化滚动条的当前位置
$(document).ready(function(){//DOM的onload事件
$(”#mypage”).load(”table.html”);//table.html的内容被加载到mypage元素
$(”#mypage”).scroll( function() {//定义滚动条位置改变时触发的事件。
hght=this.scrollHeight;//得到滚动条总长,赋给hght变量
top=this.scrollTop;//得到滚动条当前值,赋给top变量
});
});
setInterval(”cando();”,2000);//每隔2秒钟调用一次cando函数来判断当前滚动条位置。
function cando(){
if(top>parseInt(hght/3)*2)//判断滚动条当前位置是否超过总长的2/3,parseInt为取整函数
show();//如果是,调用show函数加载内容。
}
function show(){
$.get(”table.html”, function(data){//利用jquery的get方法得到table.html内容
$(”#mypage”).append(data);//用append方法追加内容到mypage元素。
hght=0;//恢复滚动条总长,因为$(”#mypage”).scroll事件一触发,又会得到新值,不恢复的话可能会造成判断错误而再次加载……
top=0;//原因同上。
});
}
</script>
<div id=”mypage”></div>

为什么要隔2秒钟调用一次判断呢?因为只要$(”#mypage”).scroll事件一被触发,就会影hght和top值,这个值可能总是满足cando函数的判断,也就是top值总是位于hght的三分之二。因此可能会多次加载造成服务器负担加重。而每加载一次后把hght和top值赋0,也是这个原因。

这段代码的效果就是只要元素mypage的滚动条位置位于滚动条总长的三分之二时,追加table.html的内容到元素mypage中去。当然这样运行是无休止地加载下去。在真正的AJAX运用中,table.html可以换成asp或php脚本,接收get或post参数来进行处理,然后返回有意义的数据。jquery的get方法可以设置get方式的参数数据,比如:

$.get(”test.php”, { name: “boho”, id: “1″ } );

相当于http://localhost/test.php?name=boho&id=1这种形式的http访问。然后通过get方法的回调函数来获取test.php输出的内容:

$.get(”test.php”, {name:”boho”,id:”1″},function(data){
alert(”Data Loaded: ” + data);
});
Javascript 相关文章推荐
根据判断浏览器类型屏幕分辨率自动调用不同CSS的代码
Feb 22 Javascript
jquery动态改变onclick属性导致失效的问题解决方法
Dec 04 Javascript
玩转方法:call和apply
May 08 Javascript
webpack+vue.js实现组件化详解
Oct 12 Javascript
JavaScript+Html5实现按钮复制文字到剪切板功能(手机网页兼容)
Mar 30 Javascript
微信小程序ajax实现请求服务器数据及模版遍历数据功能示例
Dec 15 Javascript
从源码里了解vue中的nextTick的使用
Nov 22 Javascript
详解Express笔记之动态渲染HTML(新手入坑)
Dec 13 Javascript
layui在form表单页面通过Validform加入简单验证的方法
Sep 06 Javascript
小程序websocket心跳库(websocket-heartbeat-miniprogram)
Feb 23 Javascript
JS JQuery获取data-*属性值方法解析
Sep 01 jQuery
Nest.js环境变量配置与序列化详解
Feb 21 Javascript
js控制当再次点击按钮时的间隔时间
Jun 03 #Javascript
node.js中使用node-schedule实现定时任务实例
Jun 03 #Javascript
node.js WEB开发中图片验证码的实现方法
Jun 03 #Javascript
node.js实现多图片上传实例
Jun 03 #Javascript
node.js正则表达式获取网页中所有链接的代码实例
Jun 03 #Javascript
jquery处理json数据实例分析
Jun 03 #Javascript
js 获取浏览器版本以此来调整CSS的样式
Jun 03 #Javascript
You might like
咖啡知识 咖啡养豆要养多久 排气又是什么
2021/03/06 新手入门
wamp下修改mysql访问密码的解决方法
2013/05/07 PHP
PHP中抽象类、接口的区别与选择分析
2016/03/29 PHP
php实现的中秋博饼游戏之绘制骰子图案功能示例
2017/11/06 PHP
一个选择最快的服务器转向代码
2009/04/27 Javascript
Visual Studio中的jQuery智能提示设置方法
2010/03/27 Javascript
JavaScript 模块的循环加载实现方法
2015/12/13 Javascript
浅谈Nodejs应用主文件index.js
2016/08/28 NodeJs
原生js仿浏览器滚动条效果
2017/03/02 Javascript
打字效果动画的4种实现方法(超简单)
2017/10/18 Javascript
vue2.0+vue-dplayer实现hls播放的示例
2018/03/02 Javascript
vue.js实现插入数值与表达式的方法分析
2018/07/06 Javascript
React中使用UEditor百度富文本的方法
2018/08/22 Javascript
vue 自定义指令自动获取文本框焦点的方法
2018/08/25 Javascript
Vue.js 十五分钟入门图文教程
2018/09/12 Javascript
JS解惑之Object中的key是有序的么
2019/05/06 Javascript
Vue触发隐藏input file的方法实例详解
2019/08/14 Javascript
js回调函数原理与用法案例分析
2020/03/04 Javascript
Python使用django获取用户IP地址的方法
2015/05/11 Python
深入理解python中的闭包和装饰器
2016/06/12 Python
python中print()函数的“,”与java中System.out.print()函数中的“+”功能详解
2017/11/24 Python
Python中的CSV文件使用&quot;with&quot;语句的方式详解
2018/10/16 Python
Django admin model 汉化显示文字的实现方法
2019/08/12 Python
Python netmiko模块的使用
2020/02/14 Python
Python脚本导出为exe程序的方法
2020/03/25 Python
对python中各个response的使用说明
2020/03/28 Python
新加坡最佳婴儿用品店:Mamahood.com.sg
2018/08/26 全球购物
美国婚礼礼品网站:MyWeddingFavors
2018/09/26 全球购物
学生会主席就职演讲稿
2014/01/14 职场文书
安全生产责任书
2014/03/12 职场文书
演讲稿格式范文
2014/05/19 职场文书
文明好少年事迹材料
2014/08/19 职场文书
学校领导四风问题整改措施思想汇报
2014/10/09 职场文书
导游词之太行山青龙峡
2020/01/14 职场文书
canvas多重阴影发光效果实现
2021/04/20 Javascript
mysql脏页是什么
2021/07/26 MySQL