码迷,mamicode.com
首页 > 其他好文 > 详细

函数节流

时间:2020-03-09 16:21:09      阅读:53      评论:0      收藏:0      [点我收藏+]

标签:return   settime   nts   调用   initial   height   script   head   OLE   

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        div{
            height: 10000px;
        }
    </style>
</head>
<body>
    <div></div>
    

    <script>
        function throttle(fn, wait) {
            let _fn = fn, // 保存需要被延迟的函数引用
                timer,
                flags = true; // 是否首次调用

            return function() {
                let args = arguments,
                    self = this;
                if (flags) { // 如果是第一次调用不用延迟,直接执行即可
                    _fn.apply(self, args);
                    flags = false;
                    return flags;
                }
                // 如果定时器还在,说明上一次还没执行完,不往下执行
                if (timer) return false;
                timer = setTimeout(function() { // 延迟执行
                    clearTimeout(timer); // 清空上次的定时器
                    timer = null; // 销毁变量
                    _fn.apply(self, args)
                }, wait)
            }
        }

        window.onscroll = throttle(function() {
            console.log(22)
        }, 500)
    </script>
</body>
</html>

 

函数节流

标签:return   settime   nts   调用   initial   height   script   head   OLE   

原文地址:https://www.cnblogs.com/hyshi/p/12449280.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!