新闻中心

J*aScript防抖与节流函数实现

2025-10-15
浏览次数:
返回列表
防抖和节流是优化高频事件的两种手段。防抖通过延迟执行,确保事件停止触发后才执行一次回调,适用于搜索输入等场景;节流则保证在指定时间间隔内最多执行一次函数,适合滚动监听等需稳定频率的场景。两者核心区别在于:防抖关注最终状态,节流注重规律执行。根据需求选择可显著提升性能与体验。

javascript防抖与节流函数实现

在处理高频触发事件时,比如窗口缩放、滚动、输入框输入等,直接执行回调会导致性能问题。防抖(Debounce)和节流(Throttle)是两种常用的优化手段,用来控制函数的执行频率。

防抖(Debounce)

防抖的核心思想是:在事件被触发后,设置一个延迟,如果在这个延迟内事件再次被触发,则重新计时。只有当事件停止触发超过指定时间后,才会执行一次回调。

适用于搜索建议、按钮重复点击、窗口resize等场景。

示例实现:

function debounce(func, delay) {
  let timer;
  return function (...args) {
    const context = this;
    clearTimeout(timer);
    timer = setTimeout(() => {
      func.apply(context, args);
    }, delay);
  };
}

使用方式:

const sayHello = () => console.log("Hello!");
const debouncedSayHello = debounce(sayHello, 500);
window.addEventListener('resize', debouncedSayHello);

节流(Throttle)

节流的核心思想是:规定一个单位时间,在这个时间内,最多只执行一次函数。无论事件触发多少次,函数都会按照固定间隔执行。

适用于滚动加载、鼠标移动、点击提交等需要稳定执行频率的场景。

示例实现(时间戳方式):

MarsCode MarsCode

字节跳动旗下的免费AI编程工具

MarsCode 339 查看详情 MarsCode

function throttle(func, delay) {
  let previous = 0;
  return function (...args) {
    const now = Date.now();
    const context = this;
    if (now - previous >= delay) {
      func.apply(context, args);
      previous = now;
    }
  };
}

另一种实现(定时器方式):

function throttle(func, delay) {
  let timer;
  return function (...args) {
    const context = this;
    if (!timer) {
      timer = setTimeout(() => {
        func.apply(context, args);
        timer = null;
      }, delay);
    }
  };
}

使用方式:

const logPosition = () => console.log(window.scrollY);
const throttledLog = throttle(logPosition, 100);
window.addEventListener('scroll', throttledLog);

区别与选择

防抖强调“最后一次有效”,适合事件频繁触发但只需响应最终结果的场景。比如用户打字结束后再发起搜索请求。

节流强调“规律执行”,适合需要持续响应但不能太频繁的场景。比如页面滚动时监听位置更新。

根据实际需求选择合适的方式,能显著提升性能和用户体验。

基本上就这些,理解原理后可以根据项目需要扩展支持立即执行、取消功能等高级特性。

以上就是J*aScript防抖与节流函数实现的详细内容,更多请关注其它相关文章!


# 如何使用  # 甘肃seo主管  # 惠州网站建设案例  # 晋州关键词seo  # seo公司价格获客乐云seo  # 中国澳门网站建设制作  # 嘉定区seo服务  # 河北自制网站建设特点  # 国外小说关键词排名软件  # 苏州网站推广质量好  # 丹寨网站优化推广  # 如何实现  # 如何用  # javascript  # 可以使用  # 两种  # 最多  # 在这个  # 回调  # 适用于  # 防抖  # 区别  # win  # app  # java 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: HTML5原生日期选择器与jQuery UI:实现日期选择器的联动与程序化控制  c++如何使用Meson构建系统_c++比CMake更快的构建工具  如何使用纯J*aScript判断Input元素是否在特定类容器内  手机CPU怎么影响游戏体验_手机CPU对游戏性能的影响分析  Sublime Text怎么设置垂直标尺_Sublime配置Rulers规范代码长度  React/Next.js中实现列表项的动态选择与移动  深入理解J*a合成构造器:何时以及为何阻止其生成  在J*a中如何在J*a中使用异常机制记录错误日志_异常日志实践经验  必由学官方平台入口 必由学在线课堂登录地址  抖音DOU+怎么投最有效 抖音付费推广的ROI提升技巧  小米14应用无法联网原因分析_小米14网络权限修复  mcjs网页版在线存档 mcjs云存档登录入口  海棠电脑版入口_通过电脑访问海棠官网阅读  css滚动区域卡顿如何改善_css滚动问题用will-change优化渲染  C++编译期如何执行复杂计算_C++模板元编程(TMP)技巧与应用  Google翻译怎么语音输入_Google翻译语音输入功能使用与设置方法  sublime怎么覆盖插件的默认快捷键_sublime快捷键优先级与设置  Win10怎么制作U盘启动盘 Win10系统安装U盘制作教程【详解】  怎么在浏览器上运行HTML文件_浏览器运行HTML文件技巧【技巧】  提升屏幕阅读器对“m”时间单位的播报准确性:HTML与CSS组合解决方案  怎样使用“本地安全策略”提升Windows安全性_Secpol.msc配置指南【高手】  响应式容器内容自动缩放与宽高比维持教程  css链接悬停下划线样式如何自定义_使用::after结合content和transition  抓大鹅解压小游戏 抓大鹅摸鱼解压入口  自定义Bag-of-Words实现:处理带负号的词汇权重  windows10怎么关闭系统提示音_windows10彻底静音设置方法  天眼查怎么看公司融资情况 天眼查企业融资历史查询步骤【攻略】  顺丰快件物流信息 官方网站查询入口  Composer的 archive 命令怎么用_快速打包你的PHP项目及其Composer依赖  移动端XML文件怎么转换成Excel 手机和平板上的解决方案  如何有效阻止外部脚本意外修改内联样式的高度属性  韩小圈电脑版在线入口_网页版免费登录地址  Eclipse怎么运行工程_Eclipse工程运行配置说明  深入理解J*a链表中的IPosition接口与使用  汽水音乐在线解析 汽水音乐在线解析入口  Python多版本共存与虚拟环境管理深度指南  HTML空白字符处理机制:渲染、DOM与编码实践  Win10系统服务哪些可以禁用 Win10安全优化服务列表【干货】  电脑安装程序提示“错误1722”怎么办_Windows Installer服务问题解决【教程】  HTML长属性值处理:表单action路径优化与代码规范应对  《燕云十六声》两周内达九百万玩家!位居畅销榜第五  葱吃多了会怎样 葱吃多了会伤胃吗  sublime怎么进行远程开发编辑_配置rsub/rmate实现sublime编辑服务器文件  C++如何使用AddressSanitizer(ASan)_C++调试工具中检测内存访问错误的利器  PDO预处理语句中冒号的正确处理:区分SQL函数格式与命名占位符  今日头条怎么同步内容到抖音_今日头条内容同步到抖音教程  PyTorch模型训练效果不佳?深入剖析常见错误与调试技巧  Go语言JSON解析深度指南:动态访问与结构体映射实践  支付宝碰一碰设备是REDMI手机吗 博主拆机辟谣:处理器、内存都不一样  KFC套餐升级怎么获取优惠代码_KFC套餐升级活动与优惠代码获取方法 

搜索