【JS】防抖(debounce)和节流(throttle)

1. debounce(防抖)

原理

debounce 的核心思想是:事件被触发后,等一段时间(比如300ms)没有再触发时,才执行一次函数。如果在这段时间内又触发了事件,则重新计时。

场景举例

  • 输入框搜索:用户输入时不马上请求接口,等停止输入一段时间后才发送请求,避免频繁调用接口。
  • 调整窗口大小:窗口尺寸变化频繁,只在调整停止后执行一次重绘。

📝debounce 手写实现

javascript 复制代码
function debounce(func, delay) {
  let timer = null;
  return function(...args) {
    clearTimeout(timer);
    timer = setTimeout(() => {
      func.apply(this, args);
    }, delay);
  };
}

解析

  • timer 用来保存当前计时器。
  • 每次触发函数时,先清除旧的计时器。
  • 设置新的计时器,延迟 delay 毫秒后执行目标函数 func
  • apply(this, args) 保持调用时的上下文和参数。

2. throttle(节流)

原理

throttle 的核心思想是:保证在一个固定时间间隔内,函数最多执行一次。即使触发事件很多,函数调用频率也会被限制。

场景举例

  • 滚动加载:监听滚动事件时,不想频繁调用函数,节省性能。
  • 按钮连续点击防止多次提交。

📝throttle 手写实现

ini 复制代码
function throttle(func, interval) {
  let lastTime = 0;
  return function(...args) {
    const now = Date.now();
    if (now - lastTime >= interval) {
      lastTime = now;
      func.apply(this, args);
    }
  };
}

解析

  • lastTime 记录上一次执行函数的时间戳。
  • 当前时间 now 减去 lastTime 大于等于间隔时,执行函数,并更新时间戳。
  • 其他触发在这段时间内的调用都会被忽略。

总结对比

特点 debounce throttle
执行时机 停止触发后执行一次 固定时间间隔内执行一次
适用场景 输入框搜索,窗口调整等停止触发才执行 滚动监听,按钮点击限制等频率限制
触发次数 最后一次触发执行 按时间间隔执行
相关推荐
不知名的忻1 小时前
B 树与 B+ 树:面试完全指南
b树·算法·面试·b+树
Hyyy2 小时前
普通前端续命周报——第1周
前端·javascript
KaMeidebaby2 小时前
卡梅德生物技术快报|抗独特型抗体开发:半抗原检测技术瓶颈拆解,抗独特型抗体开发工程化实践
前端·数据库·人工智能·其他·百度·新浪微博
2501_940041742 小时前
纯前端创意交互:五款全新实用工具与视觉应用生成指南
前端·交互
刀法如飞2 小时前
《道德经》简单解说版-第 2 章:天下皆知美之为美
前端·后端·面试
Raink老师3 小时前
【AI面试临阵磨枪-59】企业内部 AI 系统权限、数据隔离、审计设计
人工智能·面试·职场和发展
枕星而眠3 小时前
Linux 线程:原理、属性、实战与面试避坑
linux·运维·c语言·面试
罗超驿4 小时前
22.深入剖析JDBC架构:从原生API到企业级数据交互核心
java·数据库·mysql·面试
Raink老师4 小时前
【AI面试临阵磨枪-60】微服务下 AI 能力如何封装、网关、限流、监控
人工智能·微服务·面试
小茴香3534 小时前
HTTP缓存
网络协议·http·缓存·面试