彻底学会防抖和节流

news2024/11/15 23:42:50

目录

防抖(Debounce)

节流(Throttle)

如何选择使用防抖和节流?

总结

Vue 3 中使用防抖(Debounce)和节流(Throttle)

防抖(Debounce)示例

节流(Throttle)示例


在前端开发中,性能优化是一个非常重要的课题,尤其是在处理用户与网页的频繁交互时。防抖(Debounce)和节流(Throttle)是两种常用的技术手段,用于优化高频率执行的代码,确保应用的响应既迅速又高效。虽然它们的目的相似,但它们的工作原理和适用场景有所不同。

防抖(Debounce)

定义:防抖是指在事件被触发后,等待一段时间(例如 n 毫秒),如果在这段时间内没有再次触发该事件,则执行相应的操作;如果在等待时间内事件再次被触发,则重新计时。

工作原理:

  1. 当事件首次触发时,设置一个定时器,等待 n 毫秒。
  2. 如果在 n 毫秒内事件再次被触发,则清除之前的定时器,并重新设置一个新的定时器。
  3. 只有在 n 毫秒内没有再次触发事件时,才会执行相应的操作。

适用场景:

  • 输入框搜索:用户在输入框中输入内容时,通常不希望每次按键都触发搜索请求,而是希望在用户停止输入一段时间后才发起请求。
  • 窗口大小调整:当用户调整浏览器窗口大小时,不希望每次调整都触发布局计算,而是在用户停止调整后才进行计算。
  • 按钮点击:防止用户在短时间内多次点击按钮导致重复操作。

节流(Throttle)

定义:节流是指在一定时间间隔内,无论事件被触发多少次,只执行一次操作。

工作原理:

  1. 当事件首次触发时,立即执行相应的操作,并设置一个定时器,等待 n 毫秒。
  2. 在 n 毫秒内,即使事件再次被触发,也不会执行操作。
  3. 只有在 n 毫秒后,事件再次被触发时,才会重新执行操作。

适用场景:

  • 滚动事件:当用户滚动页面时,不希望每次滚动都触发事件处理函数,而是希望在一定时间间隔内只执行一次。
  • 鼠标移动:当用户移动鼠标时,不希望每次移动都触发事件处理函数,而是希望在一定时间间隔内只执行一次。
  • 频繁的API调用:例如在游戏中,控制角色的移动,希望在一定时间间隔内只执行一次移动操作。

如何选择使用防抖和节流?

  • 防抖:适用于用户操作停止后才需要执行的场景,例如输入框搜索、窗口大小调整等。防抖确保只有在用户停止操作一段时间后才会执行相应的操作。
  • 节流:适用于需要控制事件执行频率的场景,例如滚动事件、鼠标移动等。节流确保在一定时间间隔内只执行一次操作,避免频繁触发。

总结

  • 防抖:在用户停止操作一段时间后执行操作。
  • 节流:在一定时间间隔内只执行一次操作。

Vue 3 中使用防抖(Debounce)和节流(Throttle)

在 Vue 3 中使用防抖(Debounce)和节流(Throttle)可以通过自定义指令或直接在方法中使用防抖和节流函数来实现。

防抖(Debounce)示例

假设我们有一个输入框,当用户停止输入一段时间后,我们希望触发一个搜索操作。

<template>
  <div class="search-container">
    <input v-model="searchQuery" @input="debouncedSearch" placeholder="搜索..." class="search-input" />
  </div>
</template>

<script setup>
import { ref } from 'vue';

// 定义搜索查询的绑定变量
const searchQuery = ref('');

// 使用防抖动函数来限制搜索的频率
const debounce = (func, wait) => {
  let timeout;
  return function(...args) {
    clearTimeout(timeout);
    timeout = setTimeout(() => func.apply(this, args), wait);
  };
};

// 定义实际的搜索函数
const search = () => {
  console.log('Search triggered with query:', searchQuery.value);
  // 这里可以调用搜索 API
};

// 创建一个防抖动版本的搜索函数,以减少搜索请求的频率
const debouncedSearch = debounce(search, 300);
</script>

<style scoped>
.search-container {
  display: flex;
  justify-content: center;
  margin: 20px 0;
}

.search-input {
  width: 300px;
  padding: 10px 15px;
  font-size: 16px;
  border: 1px solid #ccc;
  border-radius: 25px;
  outline: none;
  transition: border-color 0.3s ease;
}

.search-input:focus {
  border-color: #007bff;
}
</style>

节流(Throttle)示例

假设我们有一个滚动容器,用于显示大量内容。我们希望在一定时间间隔内只执行一次滚动处理函数。

<template>
  <div class="scroll-container" @scroll="throttledScroll">
    <p v-for="i in 100" :key="i" class="scroll-item">{{ i }}</p>
  </div>
</template>

<script setup>
// 节流函数,用于控制函数调用频率
const throttle = (func, wait) => {
  let lastTime = 0;
  return function (...args) {
    const now = new Date().getTime();
    if (now - lastTime >= wait) {
      func.apply(this, args);
      lastTime = now;
    }
  };
};

// 处理滚动事件的函数
const handleScroll = () => {
  console.log('Scroll event handled');
  // 这里可以处理滚动事件
};

// 使用节流函数处理滚动事件
const throttledScroll = throttle(handleScroll, 300);
</script>

<style scoped>
.scroll-container {
  height: 200px;
  overflow-y: scroll;
  border: 1px solid #ccc;
  border-radius: 5px;
  padding: 10px;
  background-color: #f9f9f9;
}

.scroll-item {
  padding: 5px 0;
  border-bottom: 1px solid #eee;
  font-size: 14px;
  color: #333;
}

.scroll-item:last-child {
  border-bottom: none;
}
</style>

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

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

相关文章

普发Pfeiffer TCP600TCP5000手侧

普发Pfeiffer TCP600TCP5000手侧

unity3d入门教程三

unity3d入门教程三 8.1游戏脚本8.2脚本的使用8.3认识脚本组件8.4帧率9.1游戏脚本9.2获取节点和组件9.3MonoBehaviour9.4父节点与子节点9.5组件的属性9.6脚本的单步调试 8.1游戏脚本 通过程序控制对象属性&#xff08;如运动&#xff0c;修改transform的位置属性&#xff09; …

【STM32】VOFA+上位机 PID调参

【STM32】VOFA上位机 PID调参 前言VOFA简介 VOFA配置VOFA动态调节PID参数VOFA控件STM32解析数据包 PID参数整定一般调节法临界比例法试凑法 前言 参考文章如下&#xff1a;VOFA使用说明 使用VOFA上位机进行PID调参 PID参数整定 VOFA VOFA是一款简单易上手的上位机调试软件&a…

vue之我不会

计算属性 例子&#xff1a; 注意&#xff1a;调用计算属性时&#xff0c;不可以带括号&#xff0c;那样调用的就是方法&#xff0c;如&#xff1a;以下调用fullName时不可funnName() <div id"root">姓&#xff1a;<input type"text" v-model"…

Go语言练习——语法实践

目录 一、数组 1.多维数组的声明和使用 2.数组与切片的转换 3.数组在函数中的使用 二、切片 1.切片的动态扩容机制 2.切片的复制与修改 3.切片在排序算法中的应用 三、结构体 1.结构体的嵌套与方法 2.结构体与JSON的序列化 3.结构体的工厂模式 四、映射 1.映射的并发访问 2.映射…

erlang学习: Mnesia Erlang数据库4

表的类型和位置 内存表 它们的速度非常快&#xff0c;但是里面的数据是易失的&#xff0c;所以如果机器崩溃或者你停止了DBMS&#xff0c;数据就会丢失。 磁盘表 磁盘表应该不会受到系统崩溃的影响&#xff08;前提是磁盘没有物理损坏&#xff09;。 当Mnesia事务写入一个表并…

Qt如何链接和使用第三方库详解

在开发Qt应用程序时&#xff0c;我们经常会遇到需要使用第三方库的情况。无论是为了实现特定的功能&#xff0c;还是为了提高开发效率&#xff0c;使用第三方库都是一个非常常见的做法。本文将详细介绍如何在Qt项目中链接和使用第三方库。 基本步骤 配置Qt项目 在Qt项目中使…

Java | Leetcode Java题解之第402题移掉K位数字

题目&#xff1a; 题解&#xff1a; class Solution {public String removeKdigits(String num, int k) {Deque<Character> deque new LinkedList<Character>();int length num.length();for (int i 0; i < length; i) {char digit num.charAt(i);while (!…

最新免费云服务器,有需要的自行领取

目前云服务器市场竞争很激烈&#xff0c;为了吸引用户上云&#xff0c;很多云服务器提供商都提供了相应的免费试用活动&#xff0c;这些活动旨在帮助用户体验其服务和产品。 以下是一些值得关注的最新免费云服务器资源及其特点&#xff1a; 一、雨云 活动地址&#xff1a;点此…

MBD_入门篇_24_SimulinkSources

24.SimulinkSources 24.1 概述 Source库里面是Simulink的产生或输入信号数据的模块&#xff0c;要么用于产生信号要么用于传递上层的信号进来要么接地。用来生成代码的模块并不是很多&#xff0c;大部分都是用来仿真的。 Source库里面的模块都只有输出&#xff0c;没有输入。…

用Unity2D制作一个人物,实现移动、跳起、人物静止和动起来时的动画:下(人物动画)

上个博客我们做出了人物的动画机和人物移动跳跃&#xff0c;接下来我们要做出人物展现出来的动画了 我们接下来就要用到动画机了&#xff0c;双击我们的动画机&#xff0c;进入到这样的页面&#xff0c;我这是已经做好的页面&#xff0c;你们是没有这些箭头的 依次像我一样连接…

大数据安全之Kerberos

Kerberos 是一个网络身份验证协议&#xff0c;旨在提供强身份验证&#xff0c;尤其是在开放网络环境中。它最早由麻省理工学院&#xff08;MIT&#xff09;开发&#xff0c;用于在不安全的网络环境中安全地验证用户身份。Kerberos 协议的设计旨在防止窃听、重放攻击和网络中的其…

工作分享,中芯国际招聘,附送內推码

內推码&#xff0c;中芯国际 &#x1f4da;【简介】&#xff1a;中芯国际(证券代码:00981.HK/688981.SH)是世界领先的集成电路晶圆代工企业之一&#xff0c;也是中国大陆集成电路制造业领导者 【详情】&#xff1a;https://nuaa.91job.org.cn/sub-station/announcementDetail…

keras和tensorflow可用的一组版本

目录 keras版本&#xff1a;3.5.0tensorflow&#xff1a;2.17.0之前的错误导包现在的正确导包 keras版本&#xff1a;3.5.0 tensorflow&#xff1a;2.17.0 之前的错误导包 其实也不是说错误&#xff0c;就是因为文件位置不对&#xff0c;所以VSCode总是有黄色波浪线&#xff0…

pycharm安装opencv

一、下载 在terminal使用pip进行安装 命令为&#xff1a;pip install opencv-python 本身下载很慢&#xff0c;可以使用清华的镜像源 ​https://pypi.tuna.tsinghua.edu.cn/simple​​ 完整的命令如下&#xff1a; pip install opencv-python -i https://pypi.tuna.tsing…

【2025届华为秋招机考三道编程题之一】华为校招留学生软件开发工程师-真题机考笔试/(200分)- 跳格子3(Java JS Python C)

华为校招机考的题型&#xff1a; 编程&#xff1a;软件测试工程师&#xff0c;算法&#xff0c;OD岗&#xff0c;三道编程题不限语言【C&#xff0c;Python&#xff0c;Java】 校招&#xff1a;600分 120分钟&#xff0c;100/200/300 社招&#xff1a;400分 150分钟&#xf…

虚拟电厂储能数据的应用

随着可再生能源的迅速增长和能源转型的推进&#xff0c;虚拟电厂&#xff08;virtualpowerplant&#xff0c;VPP&#xff09;已成为实现能源智能化管理和提高系统灵活性的关键解决方案。在虚拟电厂中&#xff0c;储能系统被视为重要的能量存储设施&#xff0c;其运行的优化对于…

论文翻译:USENIX-2021 Extracting Training Data from Large Language Models

Extracting Training Data from Large Language Models 从大型语言模型中提取训练数据 https://www.usenix.org/system/files/sec21-carlini-extracting.pdf 文章目录 从大型语言模型中提取训练数据摘要1 引言 摘要 现在&#xff0c;发布在私有数据集上训练的大型&#xff…

PyTest装饰器

控制用例执行顺序的方法在需要调整用例执行顺序的函数&#xff08;或方法&#xff09;前增加 pytest.mark.run(orderx) x表示数字数字形式&#xff1a; 小数、整数、负数 执行顺序&#xff1a; 1、由小到大 2、由正到负 3、未标记 的在正数后&#xff0c;负数前执行 顺序&a…

高并发内存池(4)——实现CentralCache

目录 一&#xff0c;CentralCache的简单介绍 二&#xff0c;CentralCache的整体结构 三&#xff0c;CentralCache实现的详细代码 1&#xff0c;成员 2&#xff0c;函数 1&#xff0c; 获取单例对象的指针 2&#xff0c; FetchRangeObj函数 3&#xff0c;GetOneSpan函数实现…