开发中的函数防抖
作者:互联网
例如我们在点击付款的时候,用户多次点击,只保留最后一次点击;
具体分析: 如图,如果用户在一定时间内再次点击,那么需要清除当前定时,如果规定时间内没点击,那么执行付款操作(执行函数);
流程如下;
// 1,高阶函数 function payMoney(){ console.log('已剁') } function debounce(func, delay){ let timer // 4.利用作用域链,如果放在内层函数, 则每次会创造新的timer return function(){ // 2.如果不使用高阶函数,里面的func会再绑定的时候直接执行 clearTimeout(timer) // 3.清除延迟在设置之前 let args = arguments; timer = setTimeout(() => { // 5. 绑定this 让this回到不用debounce的时候 func.apply(this, args) // 修正this },delay) } } button.addEventListen('click', debounce(payMoney, 1000))
标签:function,防抖,函数,debounce,timer,点击,开发,func 来源: https://www.cnblogs.com/qqfontofweb/p/16448768.html