javascript - 关于 js 节流函数的使用问题
ringa_lee
ringa_lee 2017-04-11 11:28:25
[JavaScript讨论组]

http://jsfiddle.net/haichao/f...
http://jsfiddle.net/haichao/d...

第一个 demo 可以正常执行,第二个 demo 没有正常执行。
两个 demo 区别:

btn.onclick = throttle(function () {
      console.log(1)
}, 1000)
btn.onclick = function () {
    throttle(function () {
          console.log(1)
    }, 1000)
}

另外关于 throttle 函数的实现中,return 一个 function,这个 function 并没有执行,为什么仍然执行了 fn。
求解答。

ringa_lee
ringa_lee

ringa_lee

全部回复(2)
PHP中文网

这里的关键在 throttle() 这个函数,我这里先把 throttle() 抄下来

function throttle(fn, wait) {
    var timer
    return function(...args) {
        if (!timer) {
            timer = setTimeout(() => {
                timer = null
            }, wait)
            return fn.apply(this, args)
        }
    }
}

这个函数的内部过程可以简化描述为

function throttle(fn) {
    return function() {
        fn();
    };
}

就是说,它返回一个函数,而且返回的这个函数在执行的时候会调用最外面传入的 fn

第一个 demo 中,onclick 需要赋值一个函数,而 throttle() 返回的就是一个函数,所以 onclick 得到的是 function() { fn(); },点击的时候会执行这个函数,而它会调用 fn()

第二个 demo 中,onclick 得到的是 functioin() { throttle(); },点击的时候会执行 throttle(),而 throttle() 所做的事情只是返回了 function() { fn(); },并没有调用它,所以在你看来它没有正常执行。

黄舟

节流函数,前一个先执行了所以能看到,后一个是后执行的,可能就有没有效果了

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号