首页 > 其他 > 详细

函数防抖和节流的结合

时间:2020-03-29 18:24:28      阅读:73      评论:0      收藏:0      [点我收藏+]

函数节流有个毛病,就是最后一次事件执行后,如果距离上一次事件执行不到规定时间,那么最后一次事件就不会执行,解决方法就是把事件函数节流和防抖结合在一起

 

function throlle(callback,delay){
let startTime=0;
let timer=null;
return function (){
//使用new Date().getTime(),这样首次操作一定会执行
let endTime=new Date().getTime();
clearTimeout(timer);
//第一次减法一定大雨delay,确保首次操作一定会执行
if(endTime-startTime>delay){
callback()
startTime=new Date().getTime();
}else{
//这里的目的是让最后一次执行
timer=setTimeout(()=>{
callback()
},delay)
}
}
}
document.getElementById(‘box‘).addEventListener(‘click‘,throlle(()=>{
console.log(11);
},1000))

 

函数防抖和节流的结合

原文:https://www.cnblogs.com/liuXiaoDi/p/12593522.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!