如何测试Ajax动态分页列表的最大可翻页数?

原文作者:西安鲲之鹏

原文链接:http://www.site-digger.com/html/articles/20150718/94.html

现在使用Ajax技术的网站越来越多,一个常见的应用就是动态分页:当列表页面滚动底部时,下一页的内容被动态加载(e.g. Facebook、Twitter、 Pinterest)。

和常规的分页方式相比,动态分页往往隐藏了数据总条数和页面总数,这样就增加了我们对采集成本和周期的评估的难度。

鲲鹏数据的技术人员给出了下面这段JS代码,可以帮助我们测试出列表的总页数。可以在Chrome的调试工具(F12)或者火狐的Firebug控制台内执行,效果是每隔1秒尝试将页面滚动到底部(触发加载新的内容),直至页面高度不再发生变化。

  1. var interval = 1000; // 间隔多少毫秒尝试滚动到底部一次  
  2. var page = 0; // 初始页码  
  3. var last_body_height = 0; // 上一次操作后页面的高度  
  4. function scroll_to_bottom() {   
  5.     scroll(0, document.getElementsByTagName('body')[0].scrollHeight);   
  6.     var current_body_height = document.getElementsByTagName('body')[0].scrollHeight; // 当前页面高度  
  7.     if(current_body_height != last_body_height){  
  8.         page += 1;  
  9.         console.log('Loaded page ' + page);  
  10.     }  
  11.     else{  
  12.         console.log('Page not changed, page ' + page);  
  13.     }  
  14.     last_body_height = document.getElementsByTagName('body')[0].scrollHeight; // 新的页面高度  
  15.     setTimeout('scroll_to_bottom()', interval);  
  16. }   
  17. scroll_to_bottom();  

下面是我们对雅虎问答的问题列表页的测试结果截图,可以看出最大可见页数大约是前100页。

雅虎问答列表页最大可见页数测试结果

特别说明:该文章为西安鲲之鹏的原创文章 ,你除了可以发表评论外,还可以转载到你的网站或博客,但是请保留源地址,谢谢!!(尊重他人劳动,你我共同努力)

转载于:https://my.oschina.net/webscraping/blog/511060

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值