news 2026/1/18 6:16:11

防抖和节流

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
防抖和节流

在前端开发中,防抖(Debounce)和节流(Throttle)是两种用于优化高频率触发事件(如滚动、窗口缩放、键盘输入)的技术。它们的核心目的都是为了减少函数执行次数,从而提高页面性能,避免浏览器卡顿。


1. 防抖 (Debounce)

概念:在事件被触发 n 秒后再执行回调。如果在这 n 秒内事件又被触发,则重新计时

  • 形象比喻:就像电脑休眠。如果你一直在动鼠标,电脑就不会休眠;只有当你停止操作一段时间后,电脑才会进入休眠状态。
  • 应用场景
  • 搜索框输入查询:只有当用户停止打字一段时间后,才发送 API 请求。
  • 窗口大小调整(resize):窗口调整停止后,再重新计算布局。

2. 节流 (Throttle)

概念:规定在一个单位时间内,只能触发一次函数。如果在这个单位时间内触发了多次事件,只有**第一次(或最后一次)**生效。

  • 形象比喻:就像技能冷却(CD)。当你放了一个大招后,无论你狂按多少次按键,在冷却时间结束前,技能都不会再次释放。
  • 应用场景
  • 滚动监听(scroll):比如加载更多或计算瀑布流位置,不需要每滚动 1px 就计算一次,而是每隔 200ms 计算一次。
  • 抢购按钮点击:防止用户快速连续点击导致发送过多请求。

3. 直观对比总结

特性防抖 (Debounce)节流 (Throttle)
核心思想只要你一直触发,我就一直不执行。只看最后一次无论你触发多快,我都按固定频率执行。细水长流
触发点事件停止触发一段时间后执行。事件触发期间,每隔一段时间执行一次。
主要目的减少由于连续触发带来的不必要执行。均匀分布执行过滤,控制流量。

4. 简易代码实现 (JavaScript)

防抖函数
functiondebounce(fn,delay){lettimer=null;returnfunction(...args){if(timer)clearTimeout(timer);// 如果有计时器,直接清除并重新开始timer=setTimeout(()=>{fn.apply(this,args);},delay);};}
节流函数 (时间戳版)
functionthrottle(fn,delay){letlastTime=0;returnfunction(...args){letnow=Date.now();if(now-lastTime>delay){// 只有当前时间与上次执行时间间隔大于 delay 才执行fn.apply(this,args);lastTime=now;}};}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/1/16 10:25:33

Kotaemon在华为云上的部署实践:全流程记录

Kotaemon在华为云上的部署实践:全流程记录 在企业智能客服、知识库问答系统日益普及的今天,一个真正“可用”的AI代理不仅要能回答问题,更要答得准、有依据、可维护。然而现实是,许多基于大模型的聊天机器人仍困于“幻觉频发”“…

作者头像 李华
网站建设 2026/1/16 1:13:03

校园便利平台|基于springboot + vue校园便利平台系统(源码+数据库+文档)

校园便利平台 目录 基于springboot vue校园便利平台系统 一、前言 二、系统功能演示 三、技术选型 四、其他项目参考 五、代码参考 六、测试参考 七、最新计算机毕设选题推荐 八、源码获取: 基于springboot vue校园便利平台系统 一、前言 博主介绍&…

作者头像 李华
网站建设 2026/1/16 16:31:35

38、Linux 脚本编程:bc 计算器、数组与特殊技巧

Linux 脚本编程:bc 计算器、数组与特殊技巧 1. bc - 任意精度计算器语言 在处理整数运算时,shell 能满足很多需求,但当需要进行高级数学运算或使用浮点数时,shell 就显得力不从心了。这时可以借助外部程序,比如 bc 。 bc 是许多 Linux 系统上都有的计算器程序,它能…

作者头像 李华
网站建设 2026/1/16 19:36:15

揭秘高亮车灯升级2025年值得推荐的TOP8车灯产品

在2025年,车灯升级已成为车主关注的热点之一,尤其是高亮车灯的选择。作为提升行车安全与舒适性的关键装备,市场上涌现出多款值得推荐的车灯产品。从LED日行灯到高效的激光透镜,这些产品通过先进的技术改善了照明效果和能效。为满足…

作者头像 李华
网站建设 2026/1/17 12:05:23

WSL2 / Ubuntu 下用 SDKMAN 管理多版本 Java(项目级切换,真香)

WSL2 / Ubuntu 下用 SDKMAN 管理多版本 Java(项目级切换,真香) 在 WSL2 Ubuntu 做 Java 后端开发时,经常会遇到这种组合: 老项目还在 Java 8新项目已经是 Java 17 / 21同一台机器、同一个终端,需要随时切换…

作者头像 李华
网站建设 2026/1/17 12:27:24

从“幻觉”到“诚实”:OpenAI 如何重新定义大模型的不靠谱问题

如果你对 Agent 可信性、模型行为、安全边界、长期对齐问题 感兴趣,欢迎关注 LuhuiDev。 我会在全平台持续更新这个系列,把论文、实验、工程直觉,慢慢拆给你看。OpenAI 如何重新定义大模型的不靠谱问题? 过去两年,几乎…

作者头像 李华