- 防抖函数
- 定义:
触发事件进行肯定工夫后才会执行响应的函数,期间如果反复触发工夫,从新计算工夫。 - 原理:
保护一个定时器,在delay工夫后触发函数,然而在delay工夫内再次触发的话,都会革除以后的 定时器从新计时。
- 举例:
防抖函数就像是坐公交,就是肯定工夫内,如果有人陆续上车,司机就不会开车,只有等肯定工夫内没人上车了,司机才开车。
- 利用:
常见于用户注册时候的手机号码验证和邮箱验证和页面元素滚动的监听。
以下以页面元素滚动监听的例子,来进行解析:
// 函数防抖var flag; window.onscroll = function(){ clearTimeout(flag); // 革除定时器 flag = setTimeout(function(){ console.log("防抖"); }, 300); };
- 节流函数
- 定义:
触发事件后,规定的工夫距离内无奈间断调用,只有上一次函数执行后,过了规定的工夫距离,能力进行下一次的函数调用。 - 原理:
通过判断是否达到规定工夫来触发函数,若没到规定工夫则应用计时器延后,而下一次事件则会从新设定计时器。。
- 举例:
防抖函数就像是坐动车,动车到站(触发事件)关上车门在规定工夫容许乘客上下车,如果到了规定工夫,就敞开车门,从新开车。
- 利用:
也罕用在监听页面元素滚动事件。因为滚动事件,是一个高频触发的事件。
以下还是以页面元素滚动监听的例子,来进行解析:
// 函数节流 let isRun = false; window.onscroll = function(){ if(isRun){ // 判断是否在运行,如果在执行中,则间接return return; } isRun = true; setTimeout(function(){ console.log("节流"); isRun = false; }, 300); }; // 函数节流的要点是,申明一个变量当标记位,记录以后代码是否在执行。 // 如果闲暇,则能够失常触发办法执行。 // 如果代码正在执行,则勾销这次办法执行,间接return。
总结
依据理论业务场景,正当的利用 防抖 和 节流 能够优化性能。