防抖:针对于高频触发事件如鼠标移动事件mousemove所做出的处理。
触发高频事件后n秒内函数只会执行一次,如果n秒内高频事件再次被触发,则重新计算时间。
let box = document.querySelector('.box')
let timout1 = 0;
box.onmousemove = function(){
if(timout1) clearTimeout(timout1)
timout1 = setTimeout(()=>{
console.log(11);
timout1=0;
},1000)
}
box.onmousemove=debounce(f)
function movefn (f){
console.log(111);
}
节流:也是针对于高频触发事件
高频事件触发,但在n秒内只执行一次,所以节流会稀释函数的执行频率。
let box = document.querySelector('.box');
let timout = 0;
box.onmousemove= function(){
if(timout){
return ;
}
setTimeout (()=>{
console.log(1);
timout = 0;
},1000);
}
本文深入探讨了JavaScript中两种常见的事件处理优化技术——防抖和节流。防抖技术用于限制函数的执行频率,在高频触发事件如鼠标移动事件mousemove后,确保函数在设定的时间间隔后仅执行一次。而节流则是通过限制函数在设定时间内执行的次数,降低执行频率。这两个概念对于优化页面性能和提升用户体验至关重要。
1190

被折叠的 条评论
为什么被折叠?



