开发中的函数防抖

例如我们在点击付款的时候,用户多次点击,只保留最后一次点击;

具体分析: 如图,如果用户在一定时间内再次点击,那么需要清除当前定时,如果规定时间内没点击,那么执行付款操作(执行函数);

流程如下;

 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
// 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))

  

 

posted @   大桥默默学  阅读(18)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
点击右上角即可分享
微信分享提示