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 相关文章推荐
仿校内登陆框,精美,给那些很厉害但是没有设计天才的程序员
Nov 24 Javascript
基于jQuery的js分页代码
Jun 10 Javascript
纯CSS打造的导航菜单(附jquery版)
Aug 07 Javascript
Javascript改变CSS样式(局部和全局)
Dec 18 Javascript
JS实现的简单轮播图运动效果示例
Dec 22 Javascript
Angularjs 与 bower安装和使用详解
May 11 Javascript
解决vue中使用swiper插件问题及swiper在vue中的用法
Apr 04 Javascript
手把手教你vue-cli单页到多页应用的方法
May 31 Javascript
angularjs实现对表单输入改变的监控(ng-change和watch两种方式)
Aug 29 Javascript
使用Sonarqube扫描Javascript代码的示例
Dec 26 Javascript
node.js express捕获全局异常的三种方法实例分析
Dec 27 Javascript
vue+iview实现手机号分段输入框
Mar 25 Vue.js
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学习笔记 类的声明与对象实例化
2011/06/13 PHP
PHP入门教程之图像处理技巧分析
2016/09/11 PHP
PHP实现git部署的方法教程
2017/12/19 PHP
javascript 获取函数形参个数
2014/07/31 Javascript
浅析nodejs实现Websocket的数据接收与发送
2015/11/19 NodeJs
第一次接触神奇的Bootstrap菜单和导航
2016/08/01 Javascript
前端弹出对话框 js实现ajax交互
2016/09/09 Javascript
js实现对table的增加行和删除行的操作方法
2016/10/13 Javascript
JS中用三种方式实现导航菜单中的二级下拉菜单
2016/10/31 Javascript
JavaScript中如何使用cookie实现记住密码功能及cookie相关函数介绍
2016/11/10 Javascript
浅谈关于axios和session的一些事
2017/07/13 Javascript
微信小程序 上传头像的实例详解
2017/10/27 Javascript
VueJs使用Amaze ui调整列表和内容页面
2017/11/30 Javascript
关闭Vue计算属性自带的缓存功能方法
2018/03/02 Javascript
简化vuex的状态管理方案的方法
2018/06/02 Javascript
javascript实现小型区块链功能
2019/04/03 Javascript
js实现图片无缝循环轮播
2019/10/28 Javascript
Vue数据双向绑定底层实现原理
2019/11/22 Javascript
vue 获取元素额外生成的data-v-xxx操作
2020/09/09 Javascript
[47:43]完美世界DOTA2联赛PWL S3 Magama vs GXR 第二场 12.19
2020/12/24 DOTA
python文件操作相关知识点总结整理
2016/02/22 Python
Python中输入和输出(打印)数据实例方法
2019/10/13 Python
在pytorch 中计算精度、回归率、F1 score等指标的实例
2020/01/18 Python
CSS3支持IE6, 7, and 8的边框border属性
2012/12/28 HTML / CSS
人力资源经理自我评价
2014/01/04 职场文书
知名企业招聘广告词大全
2014/03/18 职场文书
片区教研活动总结
2014/07/02 职场文书
大学生党员个人剖析材料
2014/10/08 职场文书
2015年教育实习工作总结
2015/04/24 职场文书
被告答辩状范文
2015/05/22 职场文书
毕业班班主任工作总结2015
2015/07/23 职场文书
2019年作为一名实习生的述职报告
2019/09/29 职场文书
Go各时间字符串使用解析
2021/04/02 Golang
goland 清除所有的默认设置操作
2021/04/28 Golang
nginx服务器的下载安装与使用详解
2021/08/02 Servers
SQL Server删除表中的重复数据
2022/05/25 SQL Server