当前访客身份:游客 [ 登录 | 加入开源中国 ]

代码分享

当前位置:
代码分享 » JavaScript  » 网页设计与交互
BondZhan

原始JS滚动加载

BondZhan 发布于 2013年04月17日 11时, 4评/3185阅
分享到: 
收藏 +0
2

通过window.onscroll 滚动来加载内容

滚动游览器滚动条会触发 window.onscroll 滚动事件,来加载内容
抛弃所有限制代码,那么就剩下 window.onscroll 滚动事件,就立即触发加载内容

window.onscroll -> 判断每次滚动是否到页面底部 -> 准备加载,初始化其他数据

new Object() 空项目;
with 对的元素相同属性缩码
window.onscroll  滚动事件
document.createElement  创建元素
parseInt 转化为整型
window.setTimeout window.clearTimeout 对称关系,有设置set就要清除clear
Math.max 比较大小,取最大值返回
两个数字之间求余 使用“%”

标签: <无>

代码片段(1) [全屏查看所有代码]

1. [代码][JavaScript]代码     跳至 [1] [全屏预览]

 var obj = new Object();  
 obj.IsGetData = false; //是否存在数据加载  
 obj.Time = 0; //时间声明(模拟)
 // 描 述:游缆器滚动事件  
 window.onscroll = function() {  
     if (uiIsPageBottom() && !obj.IsGetData) {  
         //状态;  
         obj.IsGetData = true;  
         //模拟Ajax加载;  
         obj.Time = window.setTimeout('GetAjaxData()', 3000); //模拟Ajax加载;使用Ajax数据注释掉本行  
     }   
 }
 // 描 述:模式Ajax加载数据  
 function GetAjaxData() {  
     // 知识点:cloneNode(true) 克隆元素  
     var table = document.getElementById("Table").cloneNode(true);  
     // 用于渐变内容区分,知识点: 两个数字之间求余 使用“%”  
     table.style.backgroundColor= (obj.Index%2==0?"#999999":"#FFFFFF");  
     document.body.appendChild(table);  
     //状态  
     if (true) {  
          // 知识点: window.setTimeout window.clearTimeout 对称关系,有设置set就要清除clear  
          // (时间长了耗费系统内存,有可能回导致IE崩溃,所以清除时间点,使用Ajax返回数据注释掉本行)  
         if (obj.Time != 0) window.clearTimeout(obj.Time);   
         document.body.removeChild(obj.div);  
     }  
     obj.IsGetData = false;
 }  
 // 描 述:判断是滚动到页面底部  
 function uiIsPageBottom() {  
     var scrollTop = 0;  
     var clientHeight = 0;  
     var scrollHeight = 0;  
     if (document.documentElement && document.documentElement.scrollTop) {  
         scrollTop = document.documentElement.scrollTop;  
     } else if (document.body) {  
         scrollTop = document.body.scrollTop;  
     }  
     if (document.body.clientHeight && document.documentElement.clientHeight) {  
         clientHeight = (document.body.clientHeight < document.documentElement.clientHeight) ? document.body.clientHeight: document.documentElement.clientHeight;  
     } else {  
         clientHeight = (document.body.clientHeight > document.documentElement.clientHeight) ? document.body.clientHeight: document.documentElement.clientHeight;  
     }  
     // 知识点:Math.max 比较大小,取最大值返回  
     scrollHeight = Math.max(document.body.scrollHeight, document.documentElement.scrollHeight);  
     if (scrollTop + clientHeight == scrollHeight) {  
         return true;  
     } else {  
         return false;  
     }  
 }  


开源中国-程序员在线工具:Git代码托管 API文档大全(120+) JS在线编辑演示 二维码 更多»

发表评论 回到顶部 网友评论(4)

  • 1楼:柯南和由美 发表于 2013-04-22 14:49 回复此评论
    主要是没有效果给我们看看
  • 2楼:zyr51860212 发表于 2015-05-15 10:50 回复此评论
  • 3楼:gaoshuzhen 发表于 2017-06-13 10:46 回复此评论
    很棒,有个地方没懂~能咨询下啊?
  • 4楼:gaoshuzhen 发表于 2017-06-13 10:47 回复此评论
    //状态  
        if (true) {
          // 知识点: window.setTimeout window.clearTimeout 对称关系,有设置set就要清除clear  
          // (时间长了耗费系统内存,有可能回导致IE崩溃,所以清除时间点,使用Ajax返回数据注释掉本行)  
          if (obj.timeout != 0) window.clearTimeout(obj.timeout);


          document.body.removeChild(obj.div);
        }




    这里的if(true)  真实条件下,应该是什么条件?
开源从代码分享开始 分享代码
BondZhan的其它代码 全部(1)...