码迷,mamicode.com
首页 > 其他好文 > 详细

函数防抖和节流的结合

时间:2020-03-29 18:01:41      阅读:42      评论:0      收藏:0      [点我收藏+]

标签:mil   settime   方法   class   bsp   OLE   cli   ack   lse   

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

 

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))

 

函数防抖和节流的结合

标签:mil   settime   方法   class   bsp   OLE   cli   ack   lse   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有 京ICP备13008772号-2
迷上了代码!