jquery浏览器滚动加载技术实现方案 |
本文标签:jquery,浏览器,滚动加载 要知道,数据量增加很频繁时,要通过定位页码来找到目标数据似乎并没有什么意义 。我觉得用户体验成熟的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;//初始化滚动条总长 $(”#mypage”).scroll( function() {//定义滚动条位置改变时触发的事件 。 setInterval(”cando();”,2000);//每隔2秒钟调用一次cando函数来判断当前滚动条位置 。 function cando(){ function show(){ </script> 为什么要隔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); }); |