防抖、节流

防抖(Debounce)"和"节流(Throttle)"是前端开发中常用于优化高频率事件触发(如 scrollresizeinputmousemove 等)的两种技术。它们的核心目的是控制函数执行的频率,提高性能和用户体验。

一、防抖(Debounce)

定义: 一段时间内只执行最后一次操作,适合"只关心最后一次触发"的场景。

应用场景:

  • 搜索框输入联想
  • resize、scroll事件优化
  • 表单输入校验等

例子:

js 复制代码
复制编辑
function debounce(fn, delay) {
  let timer = null
  return function (...args) {
    if (timer) clearTimeout(timer)
    timer = setTimeout(() => {
      fn.apply(this, args)
    }, delay)
  }
}

// 使用
const handleInput = debounce(e => {
  console.log('用户停止输入:', e.target.value)
}, 500)

二、节流(Throttle)

定义: 一定时间内只执行一次操作,适合"每隔一段时间执行一次"的场景。

应用场景:

  • 页面滚动事件
  • 拖拽
  • 点击事件防止频繁提交

例子:

js 复制代码
复制编辑
function throttle(fn, interval) {
  let lastTime = 0
  return function (...args) {
    const now = Date.now()
    if (now - lastTime >= interval) {
      lastTime = now
      fn.apply(this, args)
    }
  }
}

// 使用
const handleScroll = throttle(() => {
  console.log('节流执行一次 scroll')
}, 200)

总结对比:

特性 防抖(Debounce) 节流(Throttle)
执行频率 只在最后一次事件后执行一次 固定间隔执行一次
适合场景 搜索联想、自动保存、输入监听 滚动监听、拖拽、频繁点击限制
控制方式 定时器重置 时间戳或定时器
相关推荐
熊猫钓鱼>_>15 分钟前
动态网站发布部署核心问题详解
前端·nginx·容器化·网页开发·云服务器·静态部署
方也_arkling16 分钟前
elementPlus按需导入配置
前端·javascript·vue.js
爱吃大芒果27 分钟前
Flutter for OpenHarmony 实战: mango_shop 资源文件管理与鸿蒙适配
javascript·flutter·harmonyos
我的xiaodoujiao30 分钟前
使用 Python 语言 从 0 到 1 搭建完整 Web UI自动化测试学习系列 44--将自动化测试结果自动推送至钉钉工作群聊
前端·python·测试工具·ui·pytest
沛沛老爹32 分钟前
Web开发者转型AI:多模态Agent视频分析技能开发实战
前端·人工智能·音视频
David凉宸37 分钟前
vue2与vue3的差异在哪里?
前端·javascript·vue.js
Irene199138 分钟前
JavaScript字符串转数字方法总结
javascript·隐式转换
笔画人生42 分钟前
Cursor + 蓝耘API:用自然语言完成全栈项目开发
前端·后端
AC赳赳老秦1 小时前
外文文献精读:DeepSeek翻译并解析顶会论文核心技术要点
前端·flutter·zookeeper·自动化·rabbitmq·prometheus·deepseek
小宇的天下1 小时前
Calibre 3Dstack --每日一个命令day18【floating_trace】(3-18)
服务器·前端·数据库