什么是防抖和节流?有什么区别? 如何实现?

embedded/2024/10/25 20:23:12/

防抖(Debounce)节流(Throttle)是两种常用的技术手段,主要用于控制某个函数在一定时间内触发的次数,以减少触发频率,提高性能并避免资源浪费。

防抖(Debounce)的工作原理是,当事件持续触发时,只有在事件停止触发n秒后,才会执行事件函数。如果在n秒内事件被重新触发,那么之前的计时会被重置。这种技术通常用于如模糊搜索、短信验证和文本编辑器实时保存等场景。

节流(Throttle)的工作原理是,当事件持续触发时,每n秒只执行一次函数。如果在n秒内事件被重复触发,那么只有第一次触发的事件会生效。这种技术常用于处理如scroll事件、浏览器播放事件和window的resize等场景。

防抖(Debounce)是指在一定时间内,当函数被频繁触发时,只有在最后一次触发后的延迟时间内,函数才会被真正执行。如果在延迟时间内又有触发事件发生,会重新开始计时。防抖技术常用于搜索框输入、按钮点击等场景,避免短时间内的频繁请求。

以下是一个简单的防抖示例代码:

// 创建一个防抖函数
function debounce(func, delay) {
 let debounceTimer;
 return function () {   // 清除之前设置的定时器   clearTimeout(debounceTimer);   // 设置一个新的定时器,延迟 delay 毫秒后执行 func 函数   debounceTimer = setTimeout(() => {     func.apply(this, arguments);   }, delay); }}// 使用防抖函数
const searchInput = document.getElementById('searchInput');
const debouncedSearch = debounce(() => { console.log('执行搜索操作');}, 500);
searchInput.addEventListener('keyup', debouncedSearch);

在上述示例中,创建了一个名为 debounce 的函数,它接受一个要执行的函数 func 和延迟时间 delay。在调用 debouncedSearch 函数时,会清除之前设置的定时器,并重新设置一个定时器,在延迟时间后执行 func 函数。

节流(Throttle)是指在一定时间内,无论函数被触发多少次,函数只会在固定的时间间隔内执行一次。如果在时间间隔内有多次触发事件,只会执行最后一次。节流技术常用于滚动事件、鼠标移动等场景,限制函数的执行频率。

以下是一个简单的节流示例代码:

// 创建一个节流函数function throttle(func, delay) { let canRun = true; return function () {   if (canRun) {     func.apply(this, arguments);     canRun = false;     setTimeout(() => {       canRun = true;     }, delay);   } }}// 使用节流函数
const scrollEventHandler = throttle(() => { console.log('滚动事件触发');}, 1000);
window.addEventListener('scroll', scrollEventHandler);

在上述示例中,创建了一个名为 throttle 的函数,它同样接受一个要执行的函数 func 和延迟时间 delay。在调用 throttle 函数时,如果 canRun 为 true,则执行 func 函数,并将 canRun 设置为 false。然后,通过设置一个定时器,在延迟时间后将 canRun 设置为 true,以便下一次函数调用。

防抖和节流的主要区别在于:防抖是在最后一次触发后的延迟时间内执行函数,而节流是在固定的时间间隔内执行函数。

选择使用防抖还是节流,取决于具体的业务需求和场景。防抖更适合处理连续的快速触发事件,而节流更适合限制频繁触发事件的执行频率。

希望这个解释对你有所帮助!如果你还有其他问题,请随时提问。

欢迎加入“前端组件开发学习”交流群,一起学习成长!可关注  “前端组件开发” 公众号后,私信后申请入群。

d848d5658a07453c843277846948c608.png


http://www.ppmy.cn/embedded/9428.html

相关文章

音频文件太大了怎么办?如何实现音乐内存压缩?超实用的音频压缩技巧分享给你

一,我们需要了解音乐文件是如何存储的。 音乐文件通常以数字格式存储,如 MP3、WAV、FLAC等。这些格式各有优缺点,但共同点是它们都需要占用一定的存储空间。文件大小取决于多个因素,包括音频质量、编码格式和采样率等。因此&…

rst文件是什么?如何阅读rst文件

左手编程,右手年华。大家好,我是一点,关注我,带你走入编程的世界。 公众号:一点sir,关注领取编程资料 如果有阅读过Python源码的同学一定知道,Python社区的相关的帮助文件是用rst结尾的文档格式…

HarmonyOS ArkUI实战开发-NAPI数据类型

在前两篇文章里笔者简单介绍了 NAPI 工程结构以及生成的 cpp 源码部分,其中 JS 应用层传递过来的数据被封装在了 napi_value 中,使用前先要转换成对应的 C/C 数据类型,C/C 端的数据也要转换成 napi_value 数据类型传递给 JS 应用层&#xff0…

LocalAi,Ollama+AnythingLLM搭建部署本地大模型AI知识库,汉化版本

AnythingLLM 是一个全栈应用程序,您可以使用商业现成的 LLM 或流行的开源 LLM 和 vectorDB 解决方案来构建私有 ChatGPT,无需任何妥协,您可以在本地运行,也可以远程托管并能够智能聊天以及您提供的任何文件。 AnythingLLM 将您的文…

【Vue3】$subscribe订阅与反应

💗💗💗欢迎来到我的博客,你将找到有关如何使用技术解决问题的文章,也会找到某个技术的学习路线。无论你是何种职业,我都希望我的博客对你有所帮助。最后不要忘记订阅我的博客以获取最新文章,也欢…

Docker Desktop打开一直转圈的解决办法

安装Docker Desktop之前确保你的Hyper-V已经打开 开启后需要重新安装重新安装重新安装这是最关键的一步,博主自己看了很多教程,最后试着重装了一下解决了 安装DockerDesktop的时候我的电脑根本就没有Hyper-V这个功能选项,可能是这个问题 如…

Vitis HLS 学习笔记--优化指令-BIND_OP_STORAGE

目录 1. BIND_OP_STORAGE 概述 1.1 BIND_OP 1.2 BIND_STORAGE 2. 语法解析 2.1 BIND_OP 2.2 BIND_OP 用法示例 2.3 BIND_STORAGE 2.4 BIND_STORAGE 示例 3. 实例演示 4. 总结 1. BIND_OP_STORAGE 概述 BIND_OP_STORAGE 其实是两个优化指令的合称:BIND_OP…

Mysql基础(二)数据类型和约束

一 数据类型 讲解主要的数据类型,不面面俱到,后续遇到具体问题再查询补充扩展: 知识点的深度和广度以工作为导向 ① int float M : 表示显示宽度,M的取值范围是(0, 255)例如: int(5),当数据宽度小于5位的时候在数字前面需要用字符填满宽度说明&…