函数防抖、节流

参考文章:函数节流与函数防抖

在学习函数防抖、节流的时候遇到一个疑惑

var button = document.getElementsByClassName('button')[0];
button.addEventListener('click',
	debounce(() => {
	console.log('点完了')})
)
function debounce(fn, interval = 300) {
    let timeout = null;
    return function () {
        clearTimeout(timeout);
        timeout = setTimeout(() => {
            fn.apply(this, arguments);
        }, interval);
    };
}

debounce函数返回的是一个函数,并没有写此函数执行的语句,为什么返回一个函数就会执行呢?

问了大佬才知道,原因在于addEventListener,addEventListener接收的是debounce返回的函数,点击button的时候会执行addEventListener('event',fn,false) 这个fn,而fn是debounce(),即debounce函数执行完之后return的子函数(假设为A)。点击的时候执行A函数。

若不用addEventLS

猜你喜欢

转载自blog.csdn.net/haohong5515/article/details/89487261