zoukankan      html  css  js  c++  java
  • 下拉滚动的实现

     1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
     2     <html xmlns="http://www.w3.org/1999/xhtml">
     3     <head>
     4       <title>下拉滚动条滚到底部了吗?</title>
     5       <script language="javascript" src="jquery-1.10.2.js"></script>
     6       <script language="javascript">
     7       $(document).ready(function (){
     8         var nScrollHight = 0; //滚动距离总长(注意不是滚动条的长度)
     9         var nScrollTop = 0;   //滚动到的当前位置
    10         var nDivHight = $("#div1").height();
    11 
    12         $("#div1").scroll(function(){
    13           nScrollHight = $(this)[0].scrollHeight;
    14           nScrollTop = $(this)[0].scrollTop;
    15           if(nScrollTop + nDivHight >= nScrollHight)
    16             alert("滚动条到底部了");
    17           });
    18       });
    19       </script>
    20     <body>
    21     <div id="div1" style="overflow-y:auto; overflow-x:hidden; height:500px;">
    22       <div style="background-color:#ccc; height:750px;">IE 和 FF 下测试通过</div>
    23     </div>
    24     </body>
    25     </html>

    代码解说:
        内部div高度为750,外部div高度为500,所以垂直滚动条需要滚动750-500=250的距离,就会到达底部,参见语句nScrollTop + nDivHight >= nScrollHight。
        程序中,在外部div的scroll(滚动)事件中侦测和执行if判断语句,是非常消耗CPU资源的。用鼠标拖拉滚动条,只要有一个像素的变动就会触发该事件。但点击滚动条两头的箭头,事件触发的频率会低得多。所以滚动条的scroll事件要谨慎使用。
        本示例判断的是没有水平滚动条的情况,在有水平滚动条时,情况会有细小的变化,所以nScrollTop + nDivHight >= nScrollHight语句中,需要用“>=”比较运算符,而没有水平滚动条的时候,等号“=”就足够了。大家可以实际测试一下。还可以判断水平滚动条是否滚动到头了。

    绑在window

     1 //滚动加载
     2 $(window).on('scroll', () => {
     3     this.getScrollData();
     4 });                    
     5 
     6 //滚动加载数据
     7 getScrollData (){
     8     if(this.scroll){
     9         let totalheight = parseFloat($(window).height()) + parseFloat($(window).scrollTop());
    10         if ($(document).height() <= totalheight + 200) {
    11             this.scroll = false;
    12             this.searchKey.limit += 20;
    13             this.getTopics();
    14         }
    15     }
    16 }
  • 相关阅读:
    流量调整和限流技术
    微软开源.NET Core的执行引擎CoreCLR{转载}
    Visual Studio 2015 前端开发工作流
    基于Redis的开源分布式服务Codis
    RemoteIE 开发者可跨平台使用IE测试网页
    参加MVP OpenDay 和2015 MVP Community Camp社区大课堂
    etcd:用于服务发现的键值存储系统
    Centos7下安装mono3.10.0
    在 Azure 上使用 Docker运行 Mono
    STOMP协议介绍
  • 原文地址:https://www.cnblogs.com/terrylin/p/5343718.html
Copyright © 2011-2022 走看看