性能优化之函数防抖动

函数防抖动是一种常见的优化高频率调用函数的手段,核心是把高频率调用的函数优化为在某一时间段内只调用一次

根据具体调用的时机可以分为两种,分别是先调用防抖以及后调用防抖

先调用防抖

先调用防抖是指先调用函数,然后等待一段时间,在等待时间结束后再进行下一次调用,如果在等待时间结束前发生了多次调用,则只会响应第一次。调用时间线如下所示
在这里插入图片描述
根据这个想法,可以大致得到如下代码
在这里插入图片描述

后调用防抖

后调用防抖则是先等待一段时间,在等待时间结束后调用函数,如果在等待时间结束前再次调用,则需重新计时并等待。调用时间线如下所示
在这里插入图片描述
在原有代码基础上进行修改,增加后调用的防抖动方法
在这里插入图片描述
将防抖动的代码合并一下,得到完整的防抖动代码
在这里插入图片描述

应用场景

keyupkeydown等频繁触发的事件监听

表单验证、输入搜索、点击搜索

其他会频繁调用的函数等

总结

函数防抖动本质上是检测前后两次连续间隔内的函数调用,把时间间隔内的多次函数调用合并成一次,从而实现对频繁调用的函数的优化

先调用防抖是立即执行时间间隔内的第一次函数调用,应用场景相对较少

后调用防抖是执行时间间隔内的最后一次函数调用,应用场景相对较多

在这里插入图片描述文章来自公众号:睿江云计算
睿江云计算官网:http://www.eflycloud.com/home?from=RJ_0024

### 防抖动事件的实现与应用 #### 实现原理 防抖(Debounce)是一种通过设定延迟时间来限制函数执行的技术。其核心在于,当某事件被触发时,不会立即执行绑定的回调函数,而是等待指定的一段时间后再执行;如果在这段时间内事件再次被触发,则重新计时并推迟执行。这种机制能够有效减少因高频事件引发的性能开销。 以下是基于 JavaScript 的防抖函数实现方式: ```javascript function debounce(func, wait) { let timeout; return function(...args) { const context = this; clearTimeout(timeout); timeout = setTimeout(() => func.apply(context, args), wait); }; } ``` 此代码片段定义了一个通用的 `debounce` 函数[^3]。它接收两个参数:目标函数 `func` 和延迟时间 `wait`(单位为毫秒)。每当事件触发时,都会清除之前的定时器,并设置一个新的定时器,在经过指定的时间间隔后执行目标函数。 --- #### 应用场景 防抖技术广泛应用于各种需要降低高频率操作影响的场景中,主要包括以下几个方面: 1. **搜索框输入联想** 用户在搜索框中输入文字时,通常会伴随大量的键盘事件触发。如果不加以控制,每次按键都将发起一次网络请求或复杂计算,这不仅浪费资源还可能导致界面卡顿。利用防抖技术,可以在用户停止输入一段时间之后再发送请求,从而显著提升效率。 2. **页面滚动加载更多** 当用户向下滚动网页至底部时,可能希望动态加载新内容。然而,滚动事件本身非常频繁,直接绑定加载逻辑会造成大量无意义的操作。借助防抖方法,可以确保仅在用户完全停下滚动动作后的特定时刻才启动新的数据获取流程[^3]。 3. **窗口大小调整监听** 调整浏览器窗口尺寸同样会产生密集的 resize 事件通知。为了防止这些事件过度消耗 CPU 时间片,可以通过防抖手段延缓响应速度,使得最终效果既满足需求又兼顾性能表现[^1]。 --- #### 使用示例 下面展示了一种实际运用防抖技巧的例子——监控表单字段变化情况: ```html <input type="text" id="searchBox"> <script> const searchBox = document.getElementById('searchBox'); // 定义查询接口模拟函数 function performSearch(query) { console.log(`Searching for "${query}"`); } // 创建带防抖特性的处理器 const handleInputChange = debounce((event) => { const query = event.target.value.trim(); if (query.length > 0) { performSearch(query); } }, 500); // 绑定到 input 事件上 searchBox.addEventListener('input', handleInputChange); </script> ``` 在此案例里,我们为文本框绑定了一个经由 `debounce` 封装过的事件监听程序。这样即使用户快速敲击多个字符也不会立刻触发展示行为,而要等到他们暂停打字至少半秒钟才行[^3]。 --- ### 总结 综上所述,JavaScript 中的防抖功能是一项极其重要的工具,可以帮助开发者应对那些容易引起系统负担过高或者用户体验下降的情况。无论是针对实时交互还是异步通信环节,合理采用此类优化措施都能带来明显的改善作用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值