debounce函数的使用-侦听器debounce的使用

本文介绍了JavaScript中的debounce和throttle方法,用于限制连续事件触发的频率,防止频繁操作导致性能问题。通过实例和源码解析,帮助开发者理解这两种防抖和节流技巧在实际开发中的使用。
摘要由CSDN通过智能技术生成

当你的事件在不断触发的时候,会根据你设置的间隔时间只触发一次回调

// const f1= debounce(
    //你要执行的函数f2
, 500);

当我不断触发键盘事件,如果我触发事件的时间间隔低于500毫秒,则不会调用jj函数,这样限制了频率,就不会对身体不好啦。

用起来倒是很方便,相对应的还有 _.throttle 方法。

接下来我们看看 debounce  的源码吧 

_.debounce = function(func, wait, immediate) {
    var timeout, args, context, timestamp, result;
 
    var later = function() {
      var last = _.now() - timestamp;
 
      if (last < wait && last >= 0) {
        timeout = setTimeout(later, wait - last);
      } else {
        timeout = null;
        if (!immediate) {
          result = func.apply(context, args);
          if (!timeout) context = args = null;
        }
      }
    };
 
    return function() {
      context = this;
      args = arguments;
      timestamp = _.now();
      var callNow = immediate && !timeout;
      if (!timeout) timeout = setTimeout(later, wait);
      if (callNow) {
        result = func.apply(context, args);
        context = args = null;
      }
 
      return result;
    };
  };

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
throttle和debounce都是用于控制函数的执行频率的方法。 throttle的作用是在一段时间内只执行一次函数,比如一个按钮的点击事件,在用户多次点击时只执行一次,以免出现重复操作的情况。 debounce的作用是在一段时间内不再触发函数后再执行函数,比如用户在输入框中输入文字时,只有在停止输入一段时间后才会执行搜索操作,以免频繁触发搜索操作。 下面是throttle和debounce的使用方法: 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实现的throttle和debounce,当然也可以使用一些第三方库来实现,比如lodash的throttle和debounce函数
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值