【防抖和节流】Vue和React当中的防抖和节流处理

1 防抖和节流函数

/*** 防抖原理:一定时间内,只有最后一次操作,再过wait毫秒后才执行函数* 防抖又分为立即执行和延迟执行* - 立即执行:点击第一次就会执行,后续指定时间内的点击不会生效* - 延迟执行:指定时间内不再进行点击,也就是过了这个指定时间,才会执行一次函数,前面的n次点击不会生效** @param {Function} func 要执行的回调函数* @param {Number} wait 延时的时间* @param {Boolean} immediate 是否立即执行* @return null*/
function debounce(func, wait = 500, immediate = true) {let timer = null;return function (...args) {// 如果存在定时器,则还处在等待期间,则清除定时器,重新开始计算时间if (timer) {clearTimeout(timer);}if (immediate) {// 如果是立即执行,则第一次进入的时候,定时器为空,会立即执行一次,然后立即开启一个定时器// 短时间内触发第二次时,定时器是不为空的,那么就不会执行,只有等定时器走完,清除了timer,才会再次执行// 这样也就实现了第一次点击立即执行,后面过了指定时间,定时器为空,才会再次执行// 注意:需要注意参数和this绑定的处理if (!timer) {typeof func === "function" && func.apply(this, args);}timer = setTimeout(() => {timer = null;}, wait);} else {// 设置定时器,定时器正常走完才会执行方法,也就是指定时间内没有再次触发,才会执行timer = setTimeout(() => {typeof func === "function" && func.apply(this, args);}, wait);}};
}/*** 节流原理:当持续触发事件时,有规律地每隔一个时间间隔执行一次事件处理函数* 适用于大量触发事件的场景,譬如监听滚动事件、鼠标滑动事件等** @param {Function} func 要执行的回调函数* @param {Number} wait 延时的时间* @param {Boolean} immediate 是否立即执行* @return null*/
function throttle(func, wait = 500, immediate = true) {let isCanExecute = true; // 是否可以执行函数return function (...args) {if (immediate) {// 立即执行if (isCanExecute) {isCanExecute = false;typeof func === "function" && func.apply(this, args);setTimeout(() => {isCanExecute = true;}, wait);}} else {// 延迟执行// 第一次触发,处于可以执行的状态,会进入判断,状态设置为不可以执行,同时开启定时器,定时器当中会执行函数,执行完函数,会重置状态为可以执行// 第二次触发时,处于不可执行状态,不会进入判断,只有当内部的定时器走完后,状态设置为了true,才会进入判断,才会开启定时器if (isCanExecute) {isCanExecute = false;setTimeout(() => {typeof func === "function" && func.apply(this, args);isCanExecute = true;}, wait);}}};
}

2 Vue当中的写法

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><meta http-equiv="X-UA-Compatible" content="ie=edge" /><title>Vue</title></head><body><div id="app"><button @click="handleDebounceClick(1, 2)">按钮-防抖</button><button @click="handleThrottleClick(1, 2)">按钮-节流</button></div></body><script src="https://cdn.bootcdn.net/ajax/libs/vue/2.6.14/vue.min.js"></script><!-- utils.js文件的内容就是上述的两个函数 --><script src="../utils.js"></script><script>new Vue({el: "#app",data: {num: 123,},methods: {// 防抖handleDebounceClick: debounce(function (data1, data2) {console.log(this.num); // 读取data当中的数据console.log(data1); // 读取参数1console.log(data2); // 读取参数2}),// 节流handleThrottleClick: throttle(function (data1, data2) {console.log(this.num); // 读取data当中的数据console.log(data1); // 读取参数1console.log(data2); // 读取参数2}),},});</script>
</html>

3 React当中的写法

// utils.js文件的内容就是上述的两个函数
import { debounce, throttle } from "../utils.js";
function Demo(props) {// 防抖const handleDebounceClick = debounce((data1, data2) => {console.log(data1); // 读取参数1console.log(data2); // 读取参数2});// 节流const handleThrottleClick = throttle((data1, data2) => {console.log(data1); // 读取参数1console.log(data2); // 读取参数2});return (<React.Fragment><button onClick={() => handleDebounceClick(1, 2)}>按钮-防抖</button><button onClick={() => handleThrottleClick(1, 2)}>按钮-节流</button></React.Fragment>);
}

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

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

相关文章

干了3年功能测试,技术回到原点

简单概括一下 先说一下自己的情况&#xff0c;普通本科&#xff0c;18年通过校招进入深圳某软件公司&#xff0c;干了3年多的功能测试&#xff0c;21年的那会&#xff0c;因为大环境不好&#xff0c;我整个人心惊胆战的&#xff0c;怕自己卷铺盖走人了&#xff0c;我感觉自己不…

推荐一款优秀的json在线格式化校验工具

www.bjson.chat 这个工具是目前见过最好用的JSON工具&#xff0c; 页面简单&#xff0c;支持text&#xff0c;tree两种显示格式&#xff0c;关键词高亮显示支持亮白和暗黑两种风格最主要的是如果要格式化很长的json的话&#xff0c;这个工具还可以全屏显示&#xff0c;简直不…

非标设计之螺纹选型

目录 一、螺纹种类二、 螺纹加工&#xff1a;第一大类&#xff1a;螺纹切削第二大类&#xff1a;螺纹滚压三、螺丝钻孔和选型&#xff1a; 一、螺纹种类 一、螺纹种类 按牙型可分为三角形、梯形、矩形、锯齿形和圆弧螺纹&#xff1b; 按螺纹旋向可分为左旋和右旋&#xff1b;…

IDEA2023.2.3 servlet.java中import com.alibaba.fastjson.JSONObject;标红问题解决

IDEA提示 java: 程序包com.alibaba.fastjson不存在_mob64ca12e98e58的技术博客_51CTO博客 2023/12/1 域名小李

外文文献如何高效阅读

外文文献阅读需要一定的技巧和方法&#xff0c;以下是一些高效阅读外文文献的建议&#xff1a; 预览&#xff1a;在开始阅读之前&#xff0c;先快速浏览全文&#xff0c;了解大意和主题。这有助于您更好地理解文章的重点和目的。 标记&#xff1a;使用笔记或荧光笔等工具标记…

电脑如何录音?适合初学者的详细教程

“电脑怎么录音呀&#xff1f;参加了一个学校举办的短视频大赛&#xff0c;视频拍摄都很顺利&#xff0c;音乐却出了问题&#xff0c;朋友说可以用电脑录制一段音乐应付一下&#xff0c;可是我不会操作&#xff0c;有哪位大佬教教我&#xff01;” 声音是一种强大的媒介&#…

七天.NET 8操作SQLite入门到实战 - 第五天引入SQLite-net ORM并封装常用方法(SQLiteHelper)

前言 上一章节我们搭建好了EasySQLite的前后端框架&#xff0c;今天我们的主要任务是在后端框架中引入SQLite-net ORM并封装常用方法&#xff08;SQLiteHelper&#xff09;。 七天.NET 8操作SQLite入门到实战详细教程 第一天 SQLite 简介第二天 在 Windows 上配置 SQLite环境…

C语言每日一题(43)旋转链表

力扣 61 旋转链表 题目描述 给你一个链表的头节点 head &#xff0c;旋转链表&#xff0c;将链表每个节点向右移动 k 个位置。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5], k 2 输出&#xff1a;[4,5,1,2,3]示例 2&#xff1a; 输入&#xff1a;head [0,1,2], …

酒店 KPI绩效考核指标及应用

“路遥知马力&#xff0c;日久见人心”&#xff0c;目前国内各类型酒店风起云涌&#xff0c;大有在市场竞争中一比高下之势&#xff0c;各路精英受经济型酒店低投入高回报的市场利益驱动&#xff0c;都分分抢占市场&#xff0c;从而使国内经济型酒店的数量不断增加&#xff0c;…

⭐ Unity 开发bug —— 打包后shader失效或者bug (我这里用Shader做两张图片的合并发现了问题)

1.这里我代码没啥问题~~~编辑器里也没毛病 void Start(){// 加载底图和上层图片string backgroundImagePath Application.streamingAssetsPath "/background.jpg";Texture2D backgroundTexture new Texture2D(2, 2);byte[] backgroundImageData System.IO.File.R…

永恒之蓝漏洞复现

网安2211-202221336029 目录 1.介绍&#xff1a; 2.操作&#xff1a; 1.实验环境&#xff1a; 2.渗透实现 3.实现后操作 3.总结&#xff1a; 1.介绍&#xff1a; 1.漏洞描述&#xff1a;Eternalblue通过TCP端口445和139来利用SMBv1和NBT中的远程代码执行漏洞&#xff0…

【无标题】mmocr在云服务器上

这里写目录标题 1、创建虚拟环境2、切换和退出conda虚拟环境3. 显示、复制&#xff08;克隆&#xff09;、删除虚拟环境4、删除环境安装指示中 cd进项目文件夹开始训练模型&#xff08;python XXX.py | tee record.txt 记录训练结果&#xff09;如何在Linux服务器上安装Anacond…

数据结构--->单链表

文章目录 链表链表的分类 单链表单链表的存储结构单链表主要实现的接口函数单链表尾插动态申请新节点单链表头插单链表的尾删单链表的头删在指定位置之前插入单链表查找插入 在指定位置之后插删除指定位置元素删除指定位置之后的元素顺序输出链表销毁单链表 顺序表和单链表的区…

苍穹外卖--客户催单

需求分析 用户在小程序中点击催单按钮后&#xff0c;需要第一时间通知外卖商家 设计思路&#xff1a;* 通过WebSocket实现管理端页面和服务端保持长连接状态当用户点击催单按钮后&#xff0c;调用WebSocket的相关API实现服务端向客户端推送消息客户端浏览器解析服务端推送的…

【超全】JavaScript知识速查:JavaScript ES6标准语法

JavaScript知识速查 文章目录 JavaScript知识速查[toc]JavaScript ES6标准语法1. 变量和常量以及块级区域变量 (let):常量 (const): 2. 模板字符串3. 解构赋值数组解构:对象解构: 4. 数组和对象的扩展扩展运算符 (...):Array.from:Object.assign: 5. 类和对象定义类:继承: 6.箭…

Redis主从与哨兵架构详解

目录 主从架构 主从环境搭建 主从复制流程 1. 全量复制 2. 部分复制 主从风暴 哨兵架构 概念 哨兵环境搭建 主从架构 主从环境搭建 1. 复制一份redis.conf文件, 修改下面几行配置 port 6380 pidfile /var/run/redis_6380.pid logfile "6380.log" dir /usr/…

基于A*的网格地图最短路径问题求解

基于A*的网格地图最短路径问题求解 一、A*算法介绍、原理及步骤二、Dijkstra算法和A*的区别三、A*算法应用场景四、启发函数五、距离六、基于A*的网格地图最短路径问题求解实例分析完整代码 七、A*算法的改进思路 一、A*算法介绍、原理及步骤 A*搜索算法&#xff08;A star al…

PCB走线宽度与电流的关系表

在1 oz./sq. ft.铜重量时将温度上升限制在10C。这应该可以让您大致了解如何调整PCB中的走线尺寸。 电流&#xff08;A&#xff09;走线宽度&#xff08;mil&#xff09;1102303504805110615071808220926010300 上表适用于许多通常采用标准工艺生产的PCB&#xff0c;其目标是非…

Python按要求从多个txt文本中提取指定数据

基本想法 遍历文件夹并从中找到文件名称符合我们需求的多个.txt格式文本文件&#xff0c;并从每一个文本文件中&#xff0c;找到我们需要的指定数据&#xff0c;最后得到所有文本文件中我们需要的数据的集合 举例 如现有名为file一个文件夹&#xff0c;里面含有大量的.txt格…

C++概念相关练习题

目录 一、内存管理 二、运算符重载 三、this指针 四、构造&析构函数 一、内存管理 下面有关c内存分配堆栈说法错误的是( ) A.对于栈来讲&#xff0c;是由编译器自动管理&#xff0c;无需我们手工控制&#xff1b;对于堆来说&#xff0c;释放工作由程序员控制 B. 对…