js节流函数

2020-11-06  本文已影响0人  王二麻子88

JS节流函数

1. 节流函数的定义

/*
    fn: 是真实处理事件的回调函数
    delay: 是节流时间段
*/
function throttle(fn: Function, delay: number) {
  // last为上一次触发回调的时间, timer是定时器
  let last = 0,
    timer:any = null;
  // 将throttle处理结果当作函数返回
  return function() {
    // 保留调用时的this上下文
    let context = this;
    // 保留调用时传入的参数
    let args = arguments;
    // 记录本次触发回调的时间
    let now = +new Date();
    // 判断上次触发的时间和本次触发的时间差是否小于时间间隔的阈值
    if (now - last < delay) {
      // 如果时间间隔小于我们设定的时间间隔阈值,则为本次触发操作设立一个新的定时器
      clearTimeout(timer);
      timer = setTimeout(function() {
        last = now;
        fn.apply(context, args);
      }, delay);
    } else {
      // 如果时间间隔超出了我们设定的时间间隔阈值,那就不等了,无论如何要反馈给用户一次响应
      last = now;
      fn.apply(context, args);
    }
  };
}

2. 节流函数的用法

let divEl = document.querySelector(".demo");
div.onclick = function() {
    throttle(function(){
        console.log("hello world")
    }, 1500)
}
上一篇 下一篇

猜你喜欢

热点阅读