节流防抖:提升前端性能的秘密武器(下)

在这里插入图片描述

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6
🍨 阿珊和她的猫_CSDN个人主页
🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》
🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》

文章目录

  • 四、应用场景和优势
    • 讨论节流防抖在前端开发中的常见应用场景
    • 比较节流和防抖的优势
  • 五、实际案例分析
    • 通过具体的案例来演示节流防抖的实际效果
    • 分析在不同情况下如何选择使用节流或防抖
  • 六、总结
    • 介绍在使用节流防抖时需要注意的一些问题
    • 总结节流防抖的重要性和应用场景

四、应用场景和优势

讨论节流防抖在前端开发中的常见应用场景

节流防抖是在前端开发中常用的技术,主要用于限制某个函数在短时间内被频繁调用,从而提高应用程序的性能和用户体验。以下是一些常见的应用场景:

  1. 搜索框输入:在搜索框中输入内容时,每次输入一个字符就发送一个请求到服务器进行搜索是不合理的。使用节流可以限制请求的频率,例如每隔 500 毫秒发送一次请求。

  2. 按钮提交:在表单提交按钮上使用防抖可以避免用户连续快速点击按钮时多次发送请求。只有在用户停止点击按钮后的一段时间内,才会发送表单数据。

  3. 滚动事件:在滚动页面时,可能会触发多个事件处理函数。使用节流可以限制这些事件的处理频率,例如每隔 100 毫秒处理一次滚动事件。

  4. resize 事件:在调整窗口大小时,可能会触发多个事件处理函数。使用节流可以限制这些事件的处理频率,例如每隔 200 毫秒处理一次 resize 事件。

  5. 游戏开发:在游戏中,玩家可能会连续快速地进行操作,例如点击按钮或移动鼠标。使用节流可以限制这些操作的执行频率,避免游戏出现卡顿或不稳定的情况。

总的来说,节流防抖可以应用于需要限制某个操作或事件执行频率的场景,以提高应用程序的性能和用户体验。在实际应用中,需要根据具体情况选择合适的节流防抖策略和参数。

比较节流和防抖的优势

节流和防抖是两种常用的性能优化手段,它们都可以用来限制函数的执行频率。下面是它们的详细比较:

1. 节流(throttle):

  • 定义:在一定时间内,函数最多执行一次。
  • 优势:可以避免函数在短时间内被频繁触发,从而提高性能。
  • 劣势:可能会导致一些需要频繁触发函数的场景无法及时响应。

2. 防抖(debounce):

  • 定义:在一定时间内,函数只有最后一次触发后的延迟执行。
  • 优势:可以确保函数只在需要的时候执行,避免在短时间内被频繁触发,从而提高性能。
  • 劣势:可能会导致一些需要快速响应的场景无法及时执行。

总结:节流和防抖都是用来限制函数执行频率的优化手段,但它们针对的场景不同。节流更适合处理需要限制执行频率的场景,而防抖更适合处理需要确保只在需要时执行的场景。在实际应用中,可以根据具体需求选择使用节流或防抖。

五、实际案例分析

通过具体的案例来演示节流防抖的实际效果

以下是一个简单的示例代码,演示了节流和防抖的实际效果:

  1. 节流
// 创建一个节流函数
function throttle(func, delay) {
 // 使用 flag 来记录上次执行时间
 let flag = true; 

 return function() {
 if (flag) {
 flag = false;
 // 使用 setTimeout 延迟执行
 setTimeout(() => {
 func.apply(this, arguments);
 flag = true;
 }, delay);
 }
 }
}

// 创建一个测试函数
const exampleFunction = () => {
 console.log('函数执行!');
}

// 使用节流函数包装测试函数
const throttledFunction = throttle(exampleFunction, 1000);

// 调用节流后的函数
throttledFunction();
throttledFunction();
throttledFunction();

在上述示例中,throttle 函数接受一个要限制频率的函数 func 和一个时间间隔 delay。它返回一个新的函数,该函数会在每次调用时检查 flag 的状态。如果 flagtrue,表示上次调用还在时间间隔内,那么本次调用将被忽略。如果 flagfalse,表示上次调用已经过去了时间间隔,那么会执行 func 函数,并将 flag 设为 true。然后,使用 setTimeout 延迟一段时间后再次将 flag 设为 false,以便下一次调用可以执行。

  1. 防抖
// 创建一个防抖函数
function debounce(func, delay) {
 let debounceTimer; 

 return function() {
 const context = this;
 const args = arguments; 

 // 清除之前设置的定时器
 clearTimeout(debounceTimer);
 debounceTimer = setTimeout(() => {
 func.apply(context, args);
 }, delay);
 }
}

// 创建一个测试函数
const exampleFunction = () => {
 console.log('函数执行!');
}

// 使用防抖函数包装测试函数
const debouncedFunction = debounce(exampleFunction, 1000);

// 调用防抖后的函数
debouncedFunction();
debouncedFunction();
debouncedFunction();

在上述示例中,debounce 函数接受一个要限制频率的函数 func 和一个时间间隔 delay。它返回一个新的函数,该函数会在每次调用时清除之前设置的定时器,并重新设置一个定时器。只有在定时器到期后,才会执行 func 函数。

通过使用节流和防抖,可以有效地限制某个函数在短时间内被频繁调用,从而提高应用程序的性能和用户体验。

请注意,这只是一个简单的示例,实际应用中可能需要根据具体情况进行一些调整和优化。

分析在不同情况下如何选择使用节流或防抖

节流和防抖都是用于限制函数在短时间内被频繁调用的技术。它们的主要区别在于处理方式的不同。

节流:在指定的单位时间内,只能触发一次函数,如果这个单位时间内触发多次函数,只有一次生效。

防抖:在指定的单位时间内,只响应最后一次函数,如果这个单位时间内触发多次函数,只有最后一次生效。

在不同情况下选择使用节流或防抖,可以参考以下原则:

  1. 需要限制某个操作或事件的执行频率:如果你需要限制某个操作或事件的执行频率,例如按钮提交、搜索框输入等,可以使用节流。这样可以避免在短时间内频繁执行相同的操作,从而提高应用程序的性能和用户体验。

  2. 需要确保在用户停止操作后执行一个操作:如果你需要确保在用户停止操作后执行一个操作,例如表单提交、输入验证等,可以使用防抖。防抖可以等待用户停止操作一段时间后,再执行相应的操作,避免不必要的操作。

  3. 需要在某个时间段内只执行一次操作:如果你需要在某个时间段内只执行一次操作,例如轮询请求、定时任务等,可以使用节流。这样可以确保在指定的时间间隔内,只执行一次操作,避免重复执行。

在这里插入图片描述

总之,选择使用节流或防抖取决于具体的需求和场景。在实际应用中,可以根据具体情况选择合适的技术,以提高应用程序的性能和用户体验。

六、总结

介绍在使用节流防抖时需要注意的一些问题

在使用节流防抖时,需要注意以下一些问题:

  1. 适用场景:节流和防抖并不适用于所有场景。如果需要立即响应用户的操作,或者需要处理大量并发的请求,可能不适合使用节流或防抖。

  2. 时间间隔:选择合适的时间间隔非常重要。时间间隔过短可能导致函数频繁执行,影响性能;时间间隔过长可能导致用户体验不佳,例如按钮点击后响应过慢。

  3. 函数执行时机:在使用节流或防抖时,需要确保函数在合适的时机执行。例如,在使用防抖时,需要确保最后一次函数调用在用户停止操作后立即执行,而不是在延迟时间结束后执行。

  4. 异常处理:在函数被节流或防抖期间,如果发生异常,需要妥善处理。例如,可以使用 try-catch 块来捕获异常,避免应用程序崩溃。

  5. 避免副作用:在函数被节流或防抖期间,可能会产生一些副作用,例如修改全局变量、发送请求等。需要确保这些副作用不会在多次函数调用之间产生冲突或错误。

  6. 测试和调试:在使用节流或防抖时,需要进行充分的测试和调试,确保函数在各种情况下正常工作。可以使用调试工具来查看函数的执行情况,以便及时发现和解决问题。

总之,在使用节流防抖时,需要综合考虑性能、用户体验和代码复杂度等因素,并根据具体情况选择合适的实现方式和参数。同时,需要注意一些常见的问题和陷阱,以确保应用程序的稳定性和可靠性。

总结节流防抖的重要性和应用场景

节流防抖是一种在 JavaScript 中常用的技术,用于限制某个函数在短时间内被频繁调用。

重要性:

  1. 提升性能:通过限制函数的调用频率,可以减少不必要的计算和 DOM 操作,从而提高应用程序的性能。

  2. 优化用户体验:在用户进行连续操作时,使用节流防抖可以避免频繁的请求和刷新,提高用户体验。

  3. 减少服务器负载:限制请求的频率可以降低对服务器的负载,特别是在高并发的情况下。

在这里插入图片描述

应用场景:

  1. 搜索框输入:在用户输入搜索内容时,使用防抖可以延迟发送请求,只有在用户停止输入一段时间后才发送请求。

  2. 按钮提交:在用户连续点击提交按钮时,使用节流可以限制提交请求的频率,避免重复提交。

  3. 滚动事件:在滚动页面时,使用节流可以限制事件处理函数的执行频率,避免过度执行。

  4. 数据加载:在加载大量数据时,使用节流可以限制数据的加载频率,避免一次性加载过多数据导致页面卡顿。

在这里插入图片描述

总之,节流防抖是一种简单而有效的技术,可以在许多场景中提高应用程序的性能和用户体验。在实际应用中,需要根据具体情况选择合适的实现方式和参数,并进行充分的测试和调试。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/243007.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

小程序开发实战案例之三 | 小程序底部导航栏如何设置

小程序中最常见的功能就是底部导航栏了,今天就来看一下怎么设置一个好看的导航栏~这里我们使用的是支付宝官方小程序 IDE 做示范。 官方提供的底部导航栏 第一步:页面创建 一般的小程序会有四个 tab,我们这次也是配置四个 tab 的…

学习深度强化学习---第3部分----RL蒙特卡罗相关算法

文章目录 3.1节 蒙特卡罗法简介3.2节 蒙特卡罗策略评估3.3节 蒙特卡罗强化学习3.4节 异策略蒙特卡罗法 本部分视频所在地址:深度强化学习的理论与实践 3.1节 蒙特卡罗法简介 在其他学科中的蒙特卡罗法是一种抽样的方法。 如果状态转移概率是已知的,则是…

FMETP STREAM 2.0

FMETPSTREAM简化了Unity3D中的直播,无需编码。设置和测试仅需5分钟。 "编码器模块"将Unity游戏视图、网络摄像头、桌面、声音和麦克风输入转换为字节数据,使其完美适用于各种流媒体场景。 优化的网络模块支持Server-clients连接类型,并允许您使用单个命令向 Serve…

Facebook的DINO,无监督模型,可用于分类和分割任务

Facebook的DINO 参考:https://blog.csdn.net/hello_dear_you/article/details/133695006 代码:https://github.com/facebookresearch/dino/tree/main DINO本质上是一种自监督学习方法,其核心思想是通过在大规模的无标签数据集上进行对比学习&…

数据结构与算法:衡量算法好坏的指标——复杂度

1.复杂度 复杂度,用来分析算法执行过程中,所需要的资源。 时间复杂度是衡量所需要的时间。 空间复杂度,是衡量所需要的(内存)空间。 1.1 时间复杂度 特性 1.衡量算法执行所需时间 2.根据「常数操作」次数推定 3.一般以最大数据量N作为衡量…

关于标准库中的list(涉及STL的精华-迭代器的底层)

目录 关于list list常见接口实现 STL的精华之迭代器 关于list list的文档介绍 1. list是可以在常数范围内在任意位置进行插入和删除的序列式容器,并且该容器可以前后双向迭代。 2. list的底层是双向链表结构,双向链表中每个元素存储在互不相关的独立…

解析视频美颜SDK的算法:美肤、滤镜与实时处理

如今,美颜技术在视频处理中扮演着关键的角色,为用户提供更加精致的视觉体验。本文将深入探讨视频美颜SDK的算法,聚焦于美肤、滤镜与实时处理等方面,揭示背后的科技奥秘。 一、美肤算法的魅力 视频美颜的一个核心功能就是美肤&am…

Linux自动注册zabbix客户端(脚本化)

参考文档:https://www.zabbix.com/documentation/6.0/zh/manual/api/reference/host/create 根据zabbix版本选择适合的API文档参考 #!/bin/bashusername"Admin" password"zabbix" zabbix_api"http://www.qingtongqing.cc:19080/api_json…

Repo sync 时出现fatal_ couldn‘t find remote ref refs_heads_master问题解决

repo sync默认的origin分支是master,它默认会依赖master,但是我们的manifests分支是main,需要解决这个问题主要执行下面的几步: 更新repo到最新版本 cd .repo/repo git pull # 更新repo前往git库创建origin master 在manifests…

大数据与人工智能——神经网络是如何工作的?

大数据与人工智能——神经网络是如何工作的? 我们习惯于去了解所使用工具、中间件的底层原理,本文则旨在帮助大家了解AI模型的底层机制,让大家在学习或应用各种大模型时更加得心应手,更加适合没有AI基础的小伙伴们。 一、GPT与神…

springMVC-原理及入门案例

基本介绍 (1)springMVC是以spring为基础,因此在使用时,需要先将spring jar引入. (2)SpringMVC是MVC框架,工作在WEB层,替代Strts2.可以超越struts2框架. (3)SpringMVC相对于Struts2来说,更加简洁&#xff0…

【字符串】ABC324E

退役啦,接下来的博客全是图一乐啦 E - Joint Two Strings 题意 思路 统计两个指针的方案数一定是枚举一个,统计另一个 然后因为拼起来之后要包含 t 这个字符串,隐隐约约会感觉到和前缀后缀子序列有关 考虑预处理每个 s[i] 的最长公共前…

本地 SIEM 与云原生 SIEM:哪一种适合您?

安全信息和事件管理 (SIEM) 解决方案对于各种规模的组织监控其环境中的安全威胁至关重要。 SIEM 解决方案收集并审查来自不同来源(例如防火墙、入侵检测系统和 Web 服务器)的安全日志。随后可以利用这些数据来检测潜在威胁、检查安全事件并针对网络攻击…

某大厂机器视觉工程师被坑100万!竞业协议到底有多少坑?

特别注意竞业协议是企业与员工双方共同意愿下签订的。如果还在这个行业做,尽量不要去签订竞业协议。 今天看到,看到某大厂员工因为违反竞业协议,被要求赔偿100多万还要返还期间发放竞业协议的补偿金; 实不相瞒,我也被…

java集合的迭代器与遍历

文章目录 迭代器Iterator1、什么是Iterator2,iterator接口的API3、Irerator()方法细节解释4. Irerator的原理示意图5. forEach循环与Iterator遍历的区别与联系 ListIterator1.ListIterator的概述(1) 概念(2) 解析 2.ListIterator的生成3.ListIterator的API4.ListIte…

uniapp 单选按钮 选中默认设备

需求1:选中默认设备,113 和114 和139都可以选中一个默认设备 选中多个默认设备方法: async toSwitch(typeItem, title) {const res await this.setDefaultDev(typeItem.ibdr_devsn, typeItem.ibdr_pid)if (!res) {this.common.toast(切换默…

空气污染大屏,UI可视化大屏设计(PSD源文件)

大屏组件可以让UI设计师的工作更加便捷,使其更高效快速的完成设计任务。现分享科技空气污染大数据、空气污染大数据平台、大气环境信息资源中心、大气检测大数据中心、环境信息资源中心界面的大屏Photoshop源文件,开箱即用! 若需 更多行业 相…

input 获取焦点后样式的修改

一、实现目标 1.没有获取焦点时样子 2.获取焦点时 代码&#xff1a; <input class"input"placeholder"请输入关键字" input"loadNode" />css .input {border-radius: 14px;border:1px solid #e4e4e4;margin: 5px;margin-top: 10px;wi…

Java - 异常(三)- 声明异常(throws)和手动抛出异常throw

目录 6.3 方式2&#xff1a;声明异常&#xff08;throws&#xff09; 6.4 手动抛出异常throw 6.4.1 概述 6.4.2 使用格式&#xff1a; 6.4.3 实例代码 6.4.4 为什么要手动抛出异常对象&#xff1f; 6.4.5 如何理解“自动”和“手动” 抛出异常对象 6.4.6 注意点 ❓面试…

基于SSM架构的超市管理系统设计

基于SSM架构的超市管理系统设计 目录 基于SSM架构的超市管理系统设计 1 环境及工具1.1 IDEA软件安装1.2 JDK环境配置1.3 MySQL数据库安装1.3.1常规情况1.3.2非常规情况 1.4 Tomcat安装 2 部署与设计2.1 数据库信息创建2.2项目创建与部署 3 相关说明4 功能操作说明4.1 管理员操作…