参考文章:函数节流与函数防抖
在学习函数防抖、节流的时候遇到一个疑惑
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