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

news2024/9/28 11:19:07

在这里插入图片描述

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

文章目录

  • 一、引言
    • 介绍节流防抖的概念和重要性
    • 为什么需要节流防抖
  • 二、节流防抖的原理
    • 解释节流和防抖的基本原理
    • 二者的实现方式和应用场景
  • 三、使用 JavaScript 实现节流防抖
    • 简单的示例代码

一、引言

介绍节流防抖的概念和重要性

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

节流 是指在一定时间内,限制函数的调用次数,即如果函数在指定的时间内被调用,只有第一次调用会被执行,直到下一个指定的时间间隔才会再次执行。

防抖 是指在一定时间内,延迟函数的执行,即如果函数在指定的时间内被频繁调用,只会执行最后一次调用,之前的调用都会被取消。

这两种技术的重要性在于它们可以提高应用程序的性能和用户体验。例如,在搜索框输入时,如果每次输入一个字符就发送一个请求到服务器,可能会导致大量不必要的请求,从而降低应用程序的性能。使用节流或防抖技术可以限制请求的频率,减少服务器的负载,并提高用户体验。

另外,节流和防抖技术还可以用于其他场景,例如按钮提交、滚动事件处理等,以避免不必要的操作和提高应用程序的响应能力。

为什么需要节流防抖

需要使用节流防抖的原因有以下几点:

  1. 性能优化:在一些场景中,频繁地执行某个函数可能会导致性能问题,例如在浏览器中进行 DOM 操作或发送网络请求。通过使用节流或防抖,可以限制函数的执行频率,减少不必要的计算和资源消耗,从而提高应用程序的性能

  2. 减少冗余操作:有时候,用户可能会在短时间内快速触发同一个事件多次,而实际上只需要最后一次触发的操作被执行。例如,在搜索框中输入文字时,用户可能会连续输入多个字符,但只需要最后输入的内容进行搜索。通过使用节流或防抖,可以避免执行之前的冗余操作,只执行最后一次触发的操作。

  3. 提升用户体验:在某些情况下,频繁的操作可能会给用户带来不好的体验,例如在输入框中输入文字时,如果每次输入一个字符就发送一个请求到服务器,可能会导致页面卡顿或响应延迟。通过使用节流或防抖,可以减少这种不必要的操作,提高用户输入的流畅度和响应速度。

综上所述,节流防抖是一种用于优化性能、减少冗余操作和提升用户体验的技术手段,在需要限制某个函数的执行频率或避免短时间内多次触发同一个事件的场景中非常有用。

二、节流防抖的原理

解释节流和防抖的基本原理

节流 的基本原理是在指定的时间间隔内,只允许函数被调用一次。如果函数在该时间间隔内被再次调用,那么只有第一次调用会被执行,其他调用都会被忽略。直到时间间隔过去后,才会执行下一次调用。

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

function throttle(func, delay) {
  // 使用 flag 来记录上次执行时间
  let flag = true; 

  return function() {
    if (flag) {
      flag = false;
      setTimeout(() => {
        func.apply(this, arguments);
        flag = true;
      }, delay);
    }
  };
}

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

防抖 的基本原理是将多个连续的函数调用合并为一个,只在最后一次调用后执行函数。如果在指定的时间间隔内再次触发事件,之前的延迟操作会被取消,重新开始计时。

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

function debounce(func, delay) {
  let debounceTimer; 

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

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

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

二者的实现方式和应用场景

以下是二者实现方式和应用场景的详细解释:

  1. 节流
  • 实现方式:节流通过控制函数在指定的时间间隔内只执行一次来实现。当函数被调用时,它会检查上一次执行的时间,如果距离上次执行时间小于时间间隔,就会忽略本次调用。否则,它会执行函数,并重新开始计时。

  • 应用场景:节流适用于需要限制某个操作执行频率的场景。例如,在搜索框输入时,每次按键都会发送一个请求到服务器进行搜索。使用节流可以将请求合并为每隔一段时间发送一次,避免频繁请求导致的性能问题。

  1. 防抖
  • 实现方式:防抖通过延迟函数的执行来实现。当函数被调用时,它会启动一个定时器。如果在定时器到期前函数再次被调用,它会重置定时器并重新开始计时。只有当定时器到期且期间没有再次调用函数时,才会执行函数。

  • 应用场景:防抖适用于需要在用户操作结束后执行某个操作的场景。例如,在提交表单时,用户可能会连续点击提交按钮多次,但只希望最后一次点击提交数据。使用防抖可以确保只有最后一次点击会触发提交操作。

总的来说,节流和防抖都是用于优化性能和用户体验的技术。它们的主要区别在于节流是限制函数的执行频率,而防抖是延迟函数的执行直到用户停止操作。选择使用哪种技术取决于具体的需求和场景。

三、使用 JavaScript 实现节流防抖

简单的示例代码

以下是使用 JavaScript 实现节流防抖的简单示例代码:

  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 函数。

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

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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

我常用的几个经典Python模块

Python常用的模块非常多,主要分为内置模块和第三方模块两大类,且不同模块应用场景不同又可以分为文本类、数据结构类、数学运算类、文件系统类、爬虫类、网络通讯类等多个类型。 大家常用的内置模块比如:math、re、datetime、urllib、os、ra…

自动化测试流程详解

最近很多小伙伴问我自动化测试到底该怎么做?流程是什么样的?在每个阶段都需要注意什么?本文也就主要从自动化测试的基本流程入手,对面试自动化测试工程师的同学会有不少帮助。对于在职的朋友,也可以参考此流程&#xf…

AI扩图哪家强?我们实地测试了5款扩图工具

AI扩图的命运齿轮开始转动了。 近日,“AI扩图”在各个社交平台上频频出圈,#AI扩图#话题,在抖音平台累计播放数超7.8亿次。 何为AI扩图? AI 扩图功能给我们带来了一个观察世界的新角度。在 AI 的加持下,我们可以看到…

门窗企业网站建设作用是什么

门窗作为市场重要的组合部分,其应用广泛使得众多商家入局经营,无论大型建筑还是家庭应用,都有较高需求度,尤其对品牌商来说,无论直售还是加盟都可以获得不菲效益。 但对门窗企业来说,也需要解决几个痛点&a…

【计算思维】第14届蓝桥杯省赛计算思维U8组真题试卷

选择题 第 1 题 单选题 要把下面 4 张图片重新排列成蜗牛的画像,该如何排列这些图片?( ) A. B. C. D. 第 2 题 单选题 下图的几张牌,每次可以交换任意 2 张。 如将它们按照下面的顺序排列,最少需要交换( )次。 A.4 B.5 C.6 D.7 …

YOLOv8改进 | 2023Neck篇 | BiFPN双向特征金字塔网络(附yaml文件+代码)

一、本文介绍 本文给大家带来的改进机制是BiFPN双向特征金字塔网络,其是一种特征融合层的结构,也就是我们本文改进YOLOv8模型中的Neck部分,它的主要思想是通过多层级的特征金字塔和双向信息传递来提高精度。本文给大家带来的结构可以让大家自…

2023年贺岁电影:一眼多,二眼好多

如果从11月末开始统计,今年贺岁档共有72部贺岁片,平均一天就有2部电影上映,看完总计需要花费7400分钟。 这个数量几乎快赶上2021年到2022年贺岁片的总和。 今年电影市场快速回暖以来,多部爆款作品接力上映,持续刺激市…

项目篇 | 图书管理系统 | 图像加载与绘制

项目篇 | 图书管理系统 | 图像加载与绘制 基本介绍 首先解释清楚什么叫图像加载与绘制,意思就是说项目中需要用到一些图片资源(各种图标),我们要在图书管理系统中展示这些图片,就需要先导入图片到项目中,再加载图片资源(通过资源路径)、绘制图片(即展示)。 注:如果…

如何将Word中的表格图片转换为可编辑格式?

我们都知道,Word中的表格是一个非常有用的工具,可以让我们在文档中轻松添加和编辑各种数据。但有时候我们可能会遇到一个问题:当表格作为图片插入时,我们就不能直接编辑它了。这可怎么办呢? 别担心,我们有…

Python语言学习笔记之八(文件IO)

本课程对于有其它语言基础的开发人员可以参考和学习,同时也是记录下来,为个人学习使用,文档中有此不当之处,请谅解。 1、什么是文件I/O 在Python中,文件IO(输人/输出)是指与文件进行交互的过程。这包括读…

翻译: 生成式人工智能项目的生命周期 Lifecycle of a generative AI project

我将分享一下构建生成式AI软件应用程序的过程。首先,我们会确定项目范围,决定软件要实现的功能。例如,你可能决定建立一个餐厅声誉监控系统。接下来是实际的实施阶段。由于生成式AI使构建应用程序变得容易,你通常可以很快构建出一…

【Fastapi框架】Fastapi的使用和进阶

原文作者:我辈李想 版权声明:文章原创,转载时请务必加上原文超链接、作者信息和本声明。 文章目录 前言一、项目启动1.安装2.示例3.启动4.路由 二、进阶1.请求数据2.静态文件加载3.路由管理4.跨域配置5.自定义中间件6.使用jwt中间件 前言 一、…

轻松学习视频剪辑:视频转码批量转为序列图片技巧,从新手到高手

随着视频剪辑的普及,越来越多的爱好者开始尝试自己动手进行视频剪辑。对于新手来说,掌握一些实用的技巧是很有必要的。在视频剪辑中,有时候要将视频片段转换为序列图片,以便进行更灵活的编辑和处理。本文详解云炫AI智剪的一种简单…

Python爬虫实战(基础篇)—9获取某个城市天气(附完整代码)

文章目录 专栏导读背景1、网址(请求URL)2、查看请求方法、参数3、请求初步测试代码请求成功 4、数据清洗(lxmlxpath)【城市实时天气】【日期】lxmlxpath 代码【室外温度】【体感温度】lxmlxpath 代码【天晴情况】【全天气温】lxmlxpath 代码【气压值】【降水量】【风力情况】【…

Ransac 算法的探索和应用

Ransac 算法python 应用和实现 Ransac 算法是一种常用的图像匹配算法,在参数估计领域也经常被使用到。针对估计各种曲线的鲁棒模型参数,效果显著。这里对ransac算法进行某些探索。 python program: import numpy as np import matplotlib.pyplot as p…

UniGui使用CSS移动端按钮标题垂直

unigui移动端中按钮拉窄以后,标题无法垂直居中,是因为标题有一个padding属性,在四周撑开一段距离。会变成这样: 解决方法,用css修改padding,具体做法如下 首先给button的cls创建一个cls,例如 然后添加css&…

python numpy 两种方法将相同shape的一维数组合并为二维数组

1 np.column_stack 最简单的一种方法 将多个一维数据按【列】合并为二维数组 import numpy as np# a b 都是一维数组 a np.array((1,2,3)) b np.array((2,3,4))# 变成二维 merge np.column_stack((a,b)) # array([[1, 2],[2, 3],[3, 4]])2 np.hstack 尽管该函数也是对【列…

桂电|《操作系统》实验一:UNIX/LINUX及其使用环境(实验报告)

桂林电子科技大学2023-2024学年 第 一 学期 操作系统A 实验报告 实验名称 实验一 UNIX/LINUX及其使用环境 实验指导老师: 成绩 院 系 计算机与信息安全学院 专业 计算机科学与技术(卓越工程) 学 号 姓名 课内序…

多表查询、事务、索引

目录 数据准备 分类 内连接 外连接 子查询 事务 四大特性 索引 数据准备 SQL脚本: #建议:创建新的数据库 create database db04; use db04;-- 部门表 create table tb_dept (id int unsigned primary key auto_increment comment 主键…

物流实时数仓:数仓搭建(DWD)一

系列文章目录 物流实时数仓:采集通道搭建 物流实时数仓:数仓搭建 物流实时数仓:数仓搭建(DIM) 物流实时数仓:数仓搭建(DWD)一 文章目录 系列文章目录前言一、文件编写1.目录创建2.b…