函数防抖的核心是只执行最后一次触发的函数调用,依赖闭包保存并维护独立的定时器引用,确保多次触发时能清除旧定时器、重设新定时器,且不同实例互不干扰。函数防抖(Debounce)的核心思想是:**在事件被频繁触发时,只执行最后一次触发对应的函数调用,忽略中间的多次调用**。它依赖闭包保存定时器引用,从而在下一次触发时清除旧定时器、重设新定时器。防抖为什么需要闭包防抖必须维持一个"上一次设置的定时器 ID"变量,以便在新事件到来时能及时清除它。这个变量不能放在全局作用域(污染、冲突),也不能写在函数内部(每次调用都重置)。闭包恰好提供了一个私有、持久、与特定防抖函数绑定的存储空间。每次调用 debounce(fn, delay) 都返回一个新函数,该函数"记住"了自己专属的 timer 变量 不同防抖实例互不干扰:比如搜索框输入防抖和窗口 resize 防抖各自维护独立 timer timer 在返回的函数体内可读可写,外部无法访问,符合封装原则基础闭包实现(支持立即执行可选)以下是一个兼顾清晰性与实用性的标准实现:function debounce(fn, delay, immediate = false) {??let timer = null;??return function(...args) {????const callNow = immediate && !timer;????if (timer) clearTimeout(timer);????if (callNow) {??????fn.apply(this, args);????}????timer = setTimeout(() => {??????if (!immediate) {????????fn.apply(this, args);??????}??????timer = null;????}, delay);??};}immediate = true 表示首次触发立即执行,后续触发仍按 delay 延迟最后一次 clearTimeout(timer) 是关键操作,它依赖闭包中持续存在的 timer 引用 timer = null 在定时器回调末尾清空,避免内存残留,也便于下次判断是否为首次实际使用中的注意事项防抖不是万能的,需结合场景谨慎使用: Vozo Vozo是一款强大的AI视频编辑工具,可以帮助用户轻松重写、配音和编辑视频。
相关推荐
冬奇Lab11 小时前
每日一个开源项目(第134篇):Zvec - 阿里开源的嵌入式向量数据库,向量搜索界的 SQLitehboot11 小时前
AI工程师第二课 - 数据处理用户83562907805116 小时前
使用 Python 自动化 PowerPoint 形状布局与格式设置用户83562907805118 小时前
用 Python 自动化 PowerPoint 演讲者备注添加ClouGence1 天前
Oracle CDC 架构优化:从主库直连到 DataGuard 备库同步黄忠1 天前
01-系统架构设计-LangGraph状态机与多源异构RAGzzzzzz3101 天前
假如我是掘金管理员,我先给评论区装个'代码审查'系统无响应de神1 天前
三、用户与权限管理砍材农夫1 天前
python环境|conda安装和使用(2)程序员龙叔2 天前
编写高质量 Skill 系列 -- 如何设计需求分析与用例生成的 SKILL