节流和防抖的实现

本文介绍了JavaScript中节流和防抖的概念及其特点。节流在设定的延迟时间内,无论调用多少次只执行一次,而防抖则是延迟时间过后才执行,若期间再次调用则重新计时。两者都依赖于闭包实现。文章提供了简单实现和改进版的示例代码,并指出在使用setTimeout时需要注意this的指向问题。
摘要由CSDN通过智能技术生成

节流和防抖

特点

1.节流的特点:指定的delay时间段中,无论调用多少次方法,只触发一次。
2.防抖的特点:调用方法后,在delay时间过后,才会触发方法,如果delay内又调用方法,则重新计时。
3,实现方式:两者的实现方式都是利用闭包,闭包就是,函数 + 函数可访问的局部变量[^1](该变量可以一直保存在内存中)
4.另外俺个人觉得它俩的简单实现版还有一个特点,一个掐头儿 一个去尾儿。防抖的第一次调用不立即执行;节流的最后一次调用可能不会执行

简单实现

节流简单版

// 节流的简单实现
function throttle(method,delay){
   
  let lastTime = 0;
  return function(...args){
   
	const now = + new Date();
	if(now - lastTime > delay){
   
		method.call(this,...args);
		lastTime = now;
	}
  }
}

上述代码可以看出,节流第一次99.99%的几率会执行,另外那0.01是传的delay太大导致的哦。正常人不会这么做吧。
言归正传,通过上面节流函数封装后,最后一次的调用不一定会触发ÿ

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值