JQuery页面随滚动条动态加载效果的简单实现(推荐)


Posted in Javascript onFebruary 08, 2017

Google阅读器上有一个AJAX scollLoad效果很不错,就是阅读项目时不需要翻页,浏览器滚动条往下拉到一定位置时自动加载新的一批项目进来,一直到所有项目加载完为止。要知道,数据量增加很频繁时,要通过定位页码来找到目标数据似乎并没有什么意义。我觉得用户体验成熟的WEB应用程序应当引导用户使用TAG或搜索等功能来找到目标数据。至于浏览数据,尤其是浏览最新的数据,利用浏览器滚动条来加载,是很好的尝试……

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

jquery.js“>// 加载jquery库

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;//原因同上。
});
}

为什么要隔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://hostlocal/test.php?name=boho&id=1

这种形式的http访问。然后通过get方法的回调函数来获取test.php输出的内容:

$.get(”test.php”, {name:”boho”,id:”1″},function(data){
alert(”Data Loaded: ” + data);
});

以上这篇JQuery页面随滚动条动态加载效果的简单实现(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript实现unicode和字符的互相转换
Jul 18 Javascript
JavaScript打字小游戏代码
Dec 26 Javascript
JS测试显示屏分辨率以及屏幕尺寸的方法
Nov 22 Javascript
js实现简易的单数字随机抽奖(0-9)
Mar 19 Javascript
用JS实现轮播图效果(二)
Jun 26 Javascript
Angular.js去除页面中显示的空行方法示例
Mar 30 Javascript
9种改善AngularJS性能的方法
Nov 28 Javascript
vue2.0 兄弟组件(平级)通讯的实现代码
Jan 15 Javascript
在vue组件中使用axios的方法
Mar 16 Javascript
H5实现手机拍照和选择上传功能
Dec 18 Javascript
Vue+tracking.js 实现前端人脸检测功能
Apr 16 Javascript
JavaScript arguments.callee作用及替换方案详解
Sep 02 Javascript
setTimeout学习小结
Feb 08 #Javascript
jquery uploadify如何取消已上传成功文件
Feb 08 #Javascript
js/jquery控制页面动态加载数据 滑动滚动条自动加载事件的方法
Feb 08 #Javascript
用move.js库实现百叶窗特效
Feb 08 #Javascript
浅谈js停止事件冒泡 阻止浏览器的默认行为(阻止超连接 #)
Feb 08 #Javascript
Move.js入门
Feb 08 #Javascript
jquery ajaxfileupload异步上传插件使用详解
Feb 08 #Javascript
You might like
用PHP实现登陆验证码(类似条行码状)
2006/10/09 PHP
php 获取远程网页内容的函数
2009/09/08 PHP
php 数据库字段复用的基本原理与示例
2011/07/22 PHP
php检测图片主要颜色的方法
2015/07/01 PHP
提高php编程效率技巧
2015/08/13 PHP
详解php中反射的应用
2016/03/15 PHP
PHP 数组基本操作方法详解
2016/06/17 PHP
浅谈PHP接入(第三方登录)QQ登录 OAuth2.0 过程中遇到的坑
2017/10/13 PHP
动手学习无线电
2021/03/10 无线电
js 提交和设置表单的值
2008/12/19 Javascript
jquery 锁定弹出层实现代码
2010/02/23 Javascript
扩展Jquery插件处理mouseover时内部有子元素时发生样式闪烁
2011/12/08 Javascript
jQuery 在光标定位的地方插入文字的插件
2012/05/10 Javascript
无缝滚动js代码通俗易懂(自写)
2013/06/19 Javascript
PHP开发者必须掌握的6个关键字
2014/04/14 Javascript
Javascript编写俄罗斯方块思路及实例
2015/07/07 Javascript
基于Bootstrap实现Material Design风格表单插件 附源码下载
2016/04/18 Javascript
JavaScript 数组- Array的方法总结(推荐)
2016/07/21 Javascript
基于JavaScript表单脚本(详解)
2017/10/18 Javascript
详解用js代码触发dom事件的实现方案
2020/06/10 Javascript
vue a标签点击实现赋值方式
2020/09/07 Javascript
用python删除java文件头上版权信息的方法
2014/07/31 Python
Python使用cx_Oracle模块将oracle中数据导出到csv文件的方法
2015/05/16 Python
Python实现给qq邮箱发送邮件的方法
2015/05/28 Python
Windows系统Python直接调用C++ DLL的方法
2019/08/01 Python
python实现输入的数据在地图上生成热力图效果
2019/12/06 Python
python图形开发GUI库pyqt5的基本使用方法详解
2020/02/14 Python
Python gevent协程切换实现详解
2020/09/14 Python
理肤泉加拿大官网:La Roche-Posay加拿大
2018/07/06 全球购物
与世界上最好的跑步专业品牌合作:Fleet Feet
2019/03/22 全球购物
村干部群众路线教育活动对照检查材料
2014/10/01 职场文书
优秀工作者事迹材料
2014/12/26 职场文书
2015年食堂工作总结报告
2015/04/23 职场文书
如何在C++中调用Python
2021/05/21 Python
MySQL如何使用使用Xtrabackup进行备份和恢复
2021/06/21 MySQL
浅谈音视频 pts dts基本概念及理解
2022/08/05 数码科技