高阶函数 - 函数节流

Posted Sorrow.X

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了高阶函数 - 函数节流相关的知识,希望对你有一定的参考价值。

        /**
         * 函数节流 - 限制函数被频繁调用
         * @param  {Function} fn       [需要执行的函数]
         * @param  {[type]}   interval [限制多长的时间再重复执行fn]
         */
        var throttle = function(fn, interval) {
            var __self = fn,
                timer,
                firstTime = true;

            return function() {
                var args = arguments,
                    __me = this;

                if (firstTime) {
                    __self.apply(__me, args);
                    return firstTime = false;
                };

                if (timer) {
                    return false;
                };

                timer = setTimeout(function() {
                    clearTimeout(timer);
                    timer = null;
                    __self.apply(__me, args);
                }, interval || 500);
            };
        };

        // test
        function A() {
            console.log(‘A‘);
        };
        var A2 = throttle(A, 1000);

        setInterval(A2, 100);

 

以上是关于高阶函数 - 函数节流的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript高阶函数的用法和使用场景

《JavaScript设计模式与开发》笔记 6.高阶函数

函数节流和防抖

js数组高阶方法reduce经典用法代码分享

js数组高阶方法reduce经典用法代码分享

手写防抖、节流 hook(ts版)