防抖节流,前端生产级最佳实践

正文

很多项目里的防抖节流都是复制粘贴的老代码 ,存在内存泄漏、频繁触发、异常卡顿等问题。今天给大家一套生产可用、无 bug 的实现。

1. 防抖(debounce)

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

适用场景:

  • 搜索框输入
  • 窗口 resize
  • 表单实时验证

2. 节流(throttle)

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

适用场景:

  • 滚动加载
  • 鼠标移动
  • 高频点击

3. 常见错误

  • 不清除定时器导致内存泄漏
  • 频繁创建新函数导致不生效
  • 在 React/Vue 中每次渲染都重新生成

最佳实践

在 Vue 中:

js 复制代码
const handleInput = debounce((val) => {
  // 请求
}, 300)

在 React 中:

js 复制代码
const handleScroll = useCallback(throttle(() => {}, 300), [])

个人观点 · 仅供参考

相关推荐
橙子家13 小时前
浏览器缓存之【基础键值存储】:Local storage 和 Session storage
前端
星星在线16 小时前
MusicFree:一个「All in One」的个人音乐服务器,让听歌回归简单
前端·后端
IT_陈寒17 小时前
Redis的SETNX并发问题让我加了三天班
前端·人工智能·后端
demo007x17 小时前
Docling 文档转换以及技术架构分析
前端·后端·程序员
京东云开发者18 小时前
京东市民服务又“上新”!这次是黑龙江“龙易办”
前端
袋鱼不重18 小时前
我的神奇同事,AI 用多了居然写了个 Open In Codex
前端·后端·ai编程
Fireworks19 小时前
深入vue3源码解读 -- 1、响应式的基础概念
前端
程序员黑豆19 小时前
JDK 下载安装与配置详细教程
java·前端·ai编程
hunterandroid19 小时前
文件存储:内部存储与外部存储
前端
NorBugs19 小时前
飞机大战 Low 版 (Made in AI)
前端