函数节流与函数防抖

今天我们来学习函数节流与函数防抖,那为什么要使用函数节流与函数防抖呢?

因为某些代码会在没有间断的情况下连续重复执行(例如:滚动条事件,只要滚动条稍稍一变化,那代码就会执行一次) ,这样就会导致效率非常低,为了提高效率就要控制某个函数在一定时间内执行的次数,这就是函数节流与函数防抖的本质。

1.函数防抖

函数防抖的本质是将代码延迟执行,在一定的时间间隔后执行(这里我们假设时间间隔为500毫秒),那么下一次代码也会在500毫秒以后执行,在500毫秒内永远只执行最后触发的一次。

//debounce()函数进入页面立即执行
// debounce()必须返回函数因为事件只能调用函数
function debounce(callback,time=300){
        let t;
        return function(){    //返回的是一个逻辑,处理防抖
            clearTimeout(t);  //在500毫秒这个时间段内又滚动了一次就要把上一次的定时器清除
            t=setTimeout(callback,time);
        }
    }
// 绑定滚动条事件
window.onscroll = debounce(function(){//监听滚动条
        console.log("调用了一次");
      },500);
//将debounce函数赋值给了滚动条事件,刚一上来就赋值,相当于刚一上来就调用了一次   同时我们给debounce函数定义了两个参数,一个为函数,另一个为时间

 效果如下:

QQ录屏20220807215035

其本质就是1.在第一次调用debounce()函数的时候设置一个定时器(t),在指定的时间(time)后运行代码(callback)

2.在第二次调用debounce()函数的时候会清除上一次的定时器(t),并重新设置一个名为(t)的定时器

3.在以上操作中,如果时间间隔(500毫秒)已经过了,即定时器已经执行过了,那么上面的操作就没有任何意义了。如果时间间隔没有过,则用一个新的定时器替换上一个定时器

4.其主要在于只有在执行函数的请求停止了间隔时间之后才执行。

应用:回到顶部效果

2.函数节流 

在500毫秒的时间中只执行第一次的,即用第二次调用函数时的时间戳减去上一次调用函数时的时间戳,如果值大于500毫秒就可以继续执行,如果小于500毫秒,就不能调用函数

function throlle(callback,time){
        let lasttime=new Date().getTime();
        return function(){       //因为将throlle()函数赋值给了事件,事件执行的是函数,所以要返回函数
            let now=new Date().getTime();
            if((now-lasttime)>=time){
                fun();
                lasttime=now;
            }

        }
    }
window.onscroll = throlle(fun,500);//将函数赋值给了事件,所以一开始就调用了throlle()函数
function fun(){
        console.log("函数调用一次");
    }

 

应用:按钮点击

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
函数节流函数防抖都是为了减少目标函数的频繁执行,特别是那些计算量较大、耗费性能较多的函数函数节流适用于大量事件按照时间均匀触发的情况,而函数防抖适用于多次事件只需要响应一次的情况。 函数节流的实现方式主要是通过设置一个定时器,在指定的时间间隔内只执行一次目标函数。当事件触发时,如果定时器已经存在,则不执行目标函数,并重新开始计时,直到定时器到期后执行目标函数。这样可以将大量事件按照时间均匀分配触发,减少频繁执行目标函数的情况。 而函数防抖的实现方式是设置一个定时器,在指定的时间间隔内只执行一次目标函数。当事件触发时,如果定时器已经存在,则清除定时器并重新开始计时,直到定时器到期后执行目标函数。这样可以避免多次事件触发时频繁执行目标函数,只在最后一次事件触发后执行目标函数。 在JavaScript中,函数节流函数防抖可以通过编写相应的函数来实现。函数节流可以通过设置一个定时器,在指定的时间间隔内执行目标函数函数防抖可以通过设置一个定时器,在指定的时间间隔内只执行一次目标函数。 总结来说,函数节流函数防抖是为了减少频繁执行目标函数而设计的技术,在不同的场景中选择合适的方式可以提升性能和用户体验。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [js函数节流,js函数防抖](https://blog.csdn.net/MFWSCQ/article/details/100130519)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [js中的函数防抖函数节流](https://blog.csdn.net/m0_52900946/article/details/124778757)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值