函数防抖,就是指触发事件后在 n 秒内函数只能执行一次,若是在 n 秒内又触发了事件,则会从新计算函数执行时间。app
简单的说,当一个动做连续触发,则只执行最后一次。函数
打个比方,坐公交,司机须要等最后一我的进入才能关门。每次进入一我的,司机就会多等待几秒再关门。性能
限制一个函数在必定时间内只能执行一次。this
举个例子,乘坐地铁,过闸机时,每一个人进入后3秒后门关闭,等待下一我的进入。spa
连续的事件,只需触发一次回调的场景有:code
间隔一段时间执行一次回调的场景有:blog
函数防抖的简单实现:事件
1 const _.debounce = (func, wait) => { 2 let timer; 3 4 return () => { 5 clearTimeout(timer); 6 timer = setTimeout(func, wait); 7 }; 8 };
函数防抖在执行目标方法时,会等待一段时间。当又执行相同方法时,若前一个定时任务未执行完,则 clear
掉定时任务,从新定时。资源
1)函数节流的 setTimeout
版简单实现it
1 const _.throttle = (func, wait) => { 2 let timer; 3 4 return () => { 5 if (timer) { 6 return; 7 } 8 9 timer = setTimeout(() => { 10 func(); 11 timer = null; 12 }, wait); 13 }; 14 };
函数节流的目的,是为了限制函数一段时间内只能执行一次。所以,经过使用定时任务,延时方法执行。在延时的时间内,方法若被触发,则直接退出方法。从而,实现函数一段时间内只执行一次。
2)函数节流的时间戳版简单实现
根据函数节流的原理,咱们也能够不依赖 setTimeout
实现函数节流。
1 const throttle = (func, wait) => { 2 let last = 0; 3 return () => { 4 const current_time = +new Date(); 5 if (current_time - last > wait) { 6 func.apply(this, arguments); 7 last = +new Date(); 8 } 9 }; 10 };
其实现原理,经过比对上一次执行时间与本次执行时间的时间差与间隔时间的大小关系,来判断是否执行函数。若时间差大于间隔时间,则马上执行一次函数。并更新上一次执行时间。
相同点:
setTimeout
实现。不一样点: