节流--自己写的函数

今天老师讲的节流, 大概意思是点击间隔时间必须三秒钟以上,三秒内的连续点击无效.

大体思路: 设定两个锁, 一个对应点击的触发函数fn, 一个对应定时器,防止定时器每次点击都会设定造成多个定时器篡改函数锁.

细节上就是把锁最好定为函数的属性,这样都对应一个.还有处理好this 和 e的问题.

我感觉老是的思路是获取时间间隔, 老是的思路比较直观. 定义一个两个变量, 每次点击记录时间点, 如果下次点击和这次间隔时间不符合时间间隔, 会不执行.

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 
 4 <head>
 5     <meta charset="UTF-8">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <meta http-equiv="X-UA-Compatible" content="ie=edge">
 8     <title>Document</title>
 9 </head>
10 
11 <body>
12     <span id='demo'>
13         1111
14     </span>
15 
16     <script>
17 
18         //点了后一秒钟之内不能再点击.
19         function jieLiu(fn, time) {
20             jieLiu.flag = true;
21             jieLiu.TimeoutFlag = true;
22             return function (e) {
23                 var that = this;
24                 var arg = Array.prototype.slice.call(arguments,0);
25                 if (jieLiu.flag) {
26                     jieLiu.flag = false;
27                     fn.apply(that,arg);
28                 }
29                 if (jieLiu.TimeoutFlag) { //定时器flag, 防止每次点击开启一个定时器. 刚开始我没用这个,点击第二次后达不到预期效果
30                     jieLiu.TimeoutFlag = false;
31                     setTimeout(function () {
32                         jieLiu.flag = true;
33                         jieLiu.TimeoutFlag = true;
34                     }, time)
35                 }
36             }
37         }
38 
39         var jl = jieLiu(function (e) { console.log(this,e.target) }, 3000);
40         demo.onclick = jl;
41     </script>
42 </body>
43 
44 </html>
        function jieLiu(fn, time) {
            var lastTime = 0;
            return function (e) {
                var nowTime = new Date().getTime();
                var that = this;
                if (nowTime - lastTime > time) {
                    lastTime = nowTime;
                    var arg = Array.prototype.slice.call(arguments, 0);
                    fn.apply(that, arg);
                }
            }
        }
原文地址:https://www.cnblogs.com/dangdanghepingping/p/10901545.html