如何实现防抖和节流,以及他们的使用场景是什么?

本文探讨了防抖(debounce)和节流(throttle)的概念,防抖用于防止短时间内频繁触发事件,如登录、发短信和窗口大小调整,而节流则限制单位时间内事件的触发次数,常见于scroll事件、播放事件和input框实时搜索。文章还提供了防抖和节流的代码实现,并指出在Vue组件中使用时应注意防抖/节流函数的声明方式以正确访问vue实例。
摘要由CSDN通过智能技术生成

防抖(debounce)

防抖:防止抖动,单位时间内时间触发会被重置,避免事件被误伤触发多次。代码的实现重在清零clearTimeout

防抖场景:

1.登录,发短信,提交等按钮避免用户点击过快,以至于发送了多次请求,需要防抖

2.调整浏览器窗口大小时,resize次数过于频繁,造成计算过多,此时需要一步到位,就用到了防抖

3.文本编辑实时保存,当无任何更改操作一秒后进行保存

 

节流(throttle)

节流:控制流量,单位时间内事件只能触发一次,若这个单位时间内触发多次函数,只有一次生效。如果服务器端的限流即 Rate Limit。代码实现重在 开锁关锁 timer=timeout; timer=null

节流场景:

1. scroll 事件,每隔一秒计算一次位置信息等

2. 浏览器播放事件,每个一秒计算一次进度信息等

3. input 框实时搜索并发送请求展示下拉列表,每隔一秒发送一次请求 (也可做防抖)

代码的实现:

防抖:设置一个定时器,通过闭包,抓住定时器变量,控制定时器的添加和删除

节流:通过一个布尔变量作为状态,判断代码是否需要执行

第一步:在utils工具文件夹下建一个utils.js文件 


                
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值