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 相关文章推荐
IE和Firefox在JavaScript应用中的兼容性探讨
Apr 01 Javascript
js 父窗口控制子窗口的行为-打开,关闭,重定位,回复
Apr 20 Javascript
JavaScript学习笔记(二) js对象
Oct 25 Javascript
屏蔽网页右键复制和ctrl+c复制的js代码
Jan 04 Javascript
JavaScript中textRange对象使用方法小结
Mar 24 Javascript
基于jquery实现省市区三级联动效果
Dec 25 Javascript
基于AGS JS开发自定义贴图图层
Mar 31 Javascript
利用Angular2 + Ionic3开发IOS应用实例教程
Jan 15 Javascript
JavaScript中的事件与异常捕获详析
Feb 24 Javascript
pm2发布node配置文件ecosystem.json详解
May 15 Javascript
LayUI数据接口返回实体封装的例子
Sep 12 Javascript
vue element-ui实现动态面包屑导航
Dec 23 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生成唯一的促销/优惠/折扣码(附源码)
2012/12/28 PHP
php安装扩展mysqli的实现步骤及报错解决办法
2017/09/23 PHP
jquery 学习笔记一
2010/04/07 Javascript
一个简单的jQuery插件制作 学习过程及实例
2010/04/25 Javascript
纯js和css实现渐变色包括静态渐变和动态渐变
2014/05/29 Javascript
jQuery链使用指南
2015/01/20 Javascript
jQuery中on()方法用法实例详解
2015/02/06 Javascript
javascript实现一个简单的弹出窗
2016/02/22 Javascript
关于backbone url请求中参数带有中文存入数据库是乱码的快速解决办法
2016/06/13 Javascript
浅析JavaScript中作用域和作用域链
2016/12/06 Javascript
boostrapTable的refresh和refreshOptions区别浅析
2017/01/22 Javascript
一些可能会用到的Node.js面试题
2019/06/15 Javascript
JS实现水平遍历和嵌套递归操作示例
2019/08/15 Javascript
js将URL网址转为16进制加密与解密函数
2020/03/04 Javascript
JavaScript观察者模式原理与用法实例详解
2020/03/10 Javascript
[57:29]Alliance vs KG 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/17 DOTA
[36:09]Secret vs VG 2019国际邀请赛淘汰赛 败者组 BO3 第一场 8.24
2019/09/10 DOTA
python自定义类并使用的方法
2015/05/07 Python
python选择排序算法实例总结
2015/07/01 Python
linux环境下的python安装过程图解(含setuptools)
2017/11/22 Python
Python图像处理之直线和曲线的拟合与绘制【curve_fit()应用】
2018/12/26 Python
Python深拷贝与浅拷贝用法实例分析
2019/05/05 Python
Python输出指定字符串的方法
2020/02/06 Python
python爬虫开发之urllib模块详细使用方法与实例全解
2020/03/09 Python
Python 解决火狐浏览器不弹出下载框直接下载的问题
2020/03/09 Python
python实现npy格式文件转换为txt文件操作
2020/07/01 Python
Python+OpenCV检测灯光亮点的实现方法
2020/11/02 Python
HTML5中使用postMessage实现Ajax跨域请求的方法
2016/04/19 HTML / CSS
MYSQL基础面试题
2012/05/13 面试题
公司端午节活动方案
2014/02/04 职场文书
办公室秘书岗位职责范本
2014/02/11 职场文书
小学关爱留守儿童活动方案
2014/08/25 职场文书
2015年服务员工作总结
2015/04/08 职场文书
蜗居观后感
2015/06/11 职场文书
Python 快速验证代理IP是否有效的方法实现
2021/07/15 Python
JavaScript圣杯布局与双飞翼布局实现案例详解
2022/08/05 Javascript