zoukankan      html  css  js  c++  java
  • 节流函数(throttle)的原理

    throttle节流函数,就是一个函数调用的频率控制器;

    var safe = true;
    function throttle() {
          if (safe) {
     	lazyLoad();
              	safe = false;
              	setTimeout(function() {
                  	safe = true;
              	}, 500);
          }
        }
    


    如下代码,safe每隔500ms才会为true,所以srollFn最快500ms执行一次。

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
    </head>
    <body style="height:2000px">
    <script>
    
        /*throttle节流函数,就是一个函数调用的频率控制器;
         如下代码,safe每隔500ms才会为true,所以srollFn最快500ms执行一次。*/
    
        var num = 0;
        function lazyLoad() {
            num++;
            console.log(num);
        }
    
        var safe = true;
        function throttle() {
            if (safe) {
                lazyLoad();
                safe = false;
                setTimeout(function () {
                    safe = true;
                }, 1000);
            }
        }
        window.onscroll = throttle;
    
    
    </script>
    </body>
    </html>
  • 相关阅读:
    Java
    Java
    Java与正则表达式
    Java与UML
    用IKVMC将jar转成dll供c#调用
    日历
    提取多层嵌套Json数据
    微信公众平台获取用户openid
    配置IISExpress允许外部访问
    英文单词学习
  • 原文地址:https://www.cnblogs.com/aredleave/p/7573157.html
Copyright © 2011-2022 走看看