函数的防抖和节流

防抖

所谓防抖,就是指触发事件后在n秒内函数只能触发一次,如果在n秒内又触发了事件,则会重新计算函数执行时间。

复制代码
/*
  防抖函数
  @param {Function} func 要执行的函数
  @param {Number} wait 要等待的时间 ms
*/
function debounce(func, wait) {
  let timer = null;
  return function () {
    let context = this;
    let args = arguments;

    timer && clearTimeout(timer);
    timer = setTimeout(() => {
      func.apply(context, args)
    }, wait);
  }
}

// 使用方法
document.getElementById('btn').onclick = debounce(function () {
  this.innerHTML = '按钮' + num++;
}, 200);
复制代码

 

节流

所谓节流,就是指连续触发事件,但是在n秒中只执行一次函数。

复制代码
/*
  节流函数
  @param {Function} func 要执行的函数
  @param {Number} wait 要等待的时间 ms
*/
function throttle(func, wait) {
  // 记录上一次函数触发的时间
  let lastTime = 0;
  return function () {
    let nowTime = Date.now();
    let context = this;
    let args = arguments;
    if (nowTime - lastTime > wait) {
      // 修正this指向
      func.apply(context, args);
      lastTime = nowTime;
    }
  }
};
// 使用方法 document.onmousemove
= throttle(function () { console.log('函数触发了?') }, 200);
复制代码

 

posted @   一步一步向上爬  阅读(243)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· 展开说说关于C#中ORM框架的用法!
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
点击右上角即可分享
微信分享提示