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

发布时间 - 2026-01-10 22:55:11    点击率:

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页面随滚动条动态加载效果的简单实现(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。


# jquery  # 滚动条加载  # 使用PHP+AJAX让WordPress动态加载文章的教程  # PHP通过反射动态加载第三方类和获得类源码的实例  # php+ajax实现无刷新动态加载数据技术  # js/jquery控制页面动态加载数据 滑动滚动条自动加载事件的方法  # jQuery实现页面滚动时动态加载内容的方法  # PHP实现简单ajax Loading加载功能示例  # php+ajax+jquery实现点击加载更多内容  # jQuery+PHP+ajax实现微博加载更多内容列表功能  # PHP+jQuery实现滚屏无刷新动态加载数据功能详解  # 滚动条  # 加载  # 上有  # 给大家  # 二时  # 就会  # 很好  # 我觉得  # 尤其是  # 不需要  # 它是  # 这段  # 希望能  # 很不错  # 要知道  # 要得  # 又会  # 这篇  # 中去  # 等功能 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel如何配置.env文件管理环境变量_Laravel环境变量使用与安全管理  INTERNET浏览器怎样恢复关闭标签页_INTERNET浏览器标签恢复快捷键与方法【指南】  EditPlus中的正则表达式 实战(1)  香港服务器如何优化才能显著提升网站加载速度?  php增删改查怎么学_零基础入门php数据库操作必知基础【教程】  香港服务器网站卡顿?如何解决网络延迟与负载问题?  如何快速搭建虚拟主机网站?新手必看指南  零服务器AI建站解决方案:快速部署与云端平台低成本实践  Laravel如何部署到服务器_线上部署Laravel项目的完整流程与步骤  javascript中对象的定义、使用以及对象和原型链操作小结  如何在阿里云香港服务器快速搭建网站?  Java Adapter 适配器模式(类适配器,对象适配器)优缺点对比  百度浏览器网页无法复制文字怎么办 百度浏览器复制修复  BootStrap整体框架之基础布局组件  Linux系统运维自动化项目教程_Ansible批量管理实战  javascript基于原型链的继承及call和apply函数用法分析  Laravel如何处理CORS跨域问题_Laravel项目CORS配置与解决方案  东莞专业网站制作公司有哪些,东莞招聘网站哪个好?  Laravel如何实现用户注册和登录?(Auth脚手架指南)  如何快速搭建个人网站并优化SEO?  Laravel N+1查询问题如何解决_Eloquent预加载(Eager Loading)优化数据库查询  Win10如何卸载预装Edge扩展_Win10卸载Edge扩展教程【方法】  Java遍历集合的三种方式  如何快速搭建高效简练网站?  如何在香港服务器上快速搭建免备案网站?  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  如何做网站制作流程,*游戏网站怎么搭建?  Laravel的辅助函数有哪些_Laravel常用Helpers函数提高开发效率  如何快速配置高效服务器建站软件?  如何在 Telegram Web View(iOS)中防止键盘遮挡底部输入框  使用Dockerfile构建java web环境  微信小程序 require机制详解及实例代码  Laravel怎么使用Markdown渲染文档_Laravel将Markdown内容转HTML页面展示【实战】  如何用ChatGPT准备面试 模拟面试问答与职场话术练习教程  Laravel如何实现邮件验证激活账户_Laravel内置MustVerifyEmail接口配置【步骤】  java ZXing生成二维码及条码实例分享  如何使用 jQuery 正确渲染 Instagram 风格的标签列表  如何制作一个表白网站视频,关于勇敢表白的小标题?  如何在Windows虚拟主机上快速搭建网站?  如何在阿里云虚拟主机上快速搭建个人网站?  如何用VPS主机快速搭建个人网站?  如何在IIS中新建站点并解决端口绑定冲突?  Laravel怎么使用Intervention Image库处理图片上传和缩放  Windows10如何更改计算机工作组_Win10系统属性修改Workgroup  EditPlus 正则表达式 实战(3)  如何快速搭建高效可靠的建站解决方案?  Laravel怎么实现搜索功能_Laravel使用Eloquent实现模糊查询与多条件搜索【实例】  php8.4header发送头信息失败怎么办_php8.4header函数问题解决【解答】  使用C语言编写圣诞表白程序  如何快速搭建高效香港服务器网站?