lodash throttle和debounce

 https://lodash.com/docs#debounce

throttle(又称节流)和debounce(又称防抖)其实都是函数调用频率的控制器

throttle:将一个函数的调用频率限制在一定阈值内,例如 1s 内一个函数不能被调用两次。

debounce:当调用函数n秒后,才会执行该动作,若在这n秒内又调用该函数则将取消前一次并重新计算执行时间,举个简单的例子,我们要根据用户输入做suggest,每当用户按下键盘的时候都可以取消前一次,并且只关心最后一次输入的时间就行了。

lodash 对这两个函数又增加了一些参数,主要是以下三个:

  • leading,函数在每个等待时延的开始被调用

  • trailing,函数在每个等待时延的结束被调用

  • maxwait(debounce才有的配置),最大的等待时间,因为如果 debounce 的函数调用时间不满足条件,可能永远都无法触发,因此增加了这个配置,保证大于一段时间后一定能执行一次函数

转载于:https://www.cnblogs.com/xiaonangua/p/11549123.html

throttledebounce都是用于控制函数的执行频率的方法。 throttle的作用是在一段时间内只执行一次函数,比如一个按钮的点击事件,在用户多次点击时只执行一次,以免出现重复操作的情况。 debounce的作用是在一段时间内不再触发函数后再执行函数,比如用户在输入框中输入文字时,只有在停止输入一段时间后才会执行搜索操作,以免频繁触发搜索操作。 下面是throttledebounce的使用方法: Throttle: ```javascript function throttle(func, delay) { let prev = Date.now() - delay; return function() { const context = this; const args = arguments; const now = Date.now(); if (now - prev >= delay) { func.apply(context, args); prev = now; } } } ``` 使用方法: ```javascript function handleClick() { console.log('clicked'); } const throttledClick = throttle(handleClick, 1000); button.addEventListener('click', throttledClick); ``` Debounce: ```javascript function debounce(func, delay) { let timer; return function() { const context = this; const args = arguments; clearTimeout(timer); timer = setTimeout(function() { func.apply(context, args); }, delay); } } ``` 使用方法: ```javascript function handleInput() { console.log('searching'); } const debouncedInput = debounce(handleInput, 500); input.addEventListener('input', debouncedInput); ``` 以上代码是纯JavaScript实现的throttledebounce,当然也可以使用一些第三方库来实现,比如lodashthrottledebounce函数。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值