2021-11-11 防抖和节流的理解

防抖和节流的理解

防抖

防抖:防止抖动 是单位时间内防止事件多次触发,只触发一次,触发后会被重置。(防抖可以比作上电梯,只要一个人进来后,需要等待)业务场景在登录避免多次操作重复提交


function debounce(fn,delay){
	let timer;
	return function (){
		clearTimeout(timer);
		timer=setTimeout(fn,delay)
	}
}			

节流

节流:控制流量 是单位时间内时间只触发一次。(节流可比作红绿灯过马路,一段时间内只能过一批)。我们可以设计一种类似控制阀门一样定期开放的函数,也就是让函数执行一次后,在某个时间段内暂时失效,过了这段时间后再重新激活(类似于技能冷却时间)。

function throttle(fn,delay){
	let timer
	return function(){
		if (timer){ return }
		timer=setTimeout(()=>{
			fn()
			timer=null
		},delay)
		
	}
}

场景:
1.搜索框input事件,例如要支持输入实时搜索可以使用节流方案(间隔一段时间就必须查询相关内容),或者实现输入间隔大于某个值(如500ms),就当做用户输入完成,然后开始搜索,具体使用哪种方案要看业务需求。
2.页面resize事件,常见于需要做页面适配的时候。需要根据最终呈现的页面情况进行dom渲染(这种情形一般是使用防抖,因为只需要判断最后一次的变化情况)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值