react简单实现防抖和节流教程方法

news/2024/7/15 20:16:52 标签: react.js, javascript, ecmascript

防抖和节流可以节省资源,减小服务器端压力,提升用户体验。

在日常开发中,我们经常会有这样的需求:监听用户的输入(keyup、keydown)、浏览器窗口调整大小和滚动行为(resize)、鼠标的移动行为(mousemove)等。如果这些事件一触发我们就执行相应的事件处理函数的话,那将会造成较大的资源浪费或者给用户带来不好的体验。

这时防抖和节流就派上用场了!!

一、防抖:
防抖:触发高频事件后n秒内函数只会执行一次,如果n秒内高频事件再次被触发,则重新计算时间。
思路:每次触发事件时都取消之前的延时调用方法。
使用的本质:不允许某一行为触发。一般用于input输入框

防止抖动的意思,也就是不抖动时才进行相应的处理。比如一根拉直的弹簧,我们拨动一下它就会抖动,过一段时间后弹簧会恢复到平静的状态(从拨动弹簧使其抖动到恢复平静的时长就是代码例子的ms值)。在这个过程中,拨动弹簧的这一行为假设为事件被触发(代码中的input事件被触发),当弹簧恢复平静时我们再执行事件处理函数(代码中的sayHi函数)。基于以上假设,当我们在弹簧还没恢复到平静状态时,又不断地拨动它(清除了原来的setTimeout,并重新开始计时),因为弹簧还没恢复到平静,那么事件处理函数就一直不会被执行。只有当我们拨动它,并且之后再也不动它(也就是最后一次触发),等它恢复到平静状态时(setTimeout时间到达),事件处理函数才会被执行。

实现方法:可以借助react的ahooks库的useDebounce或者是lodash库中的_.debounce防抖

原生:(利用闭包中变量不会被销毁内存的原理)

function debounce(fn, ms) { //fn:要防抖的函数 ms:时间
let timerId // 创建一个标记用来存放定时器的返回值
return function () {
timerId && clearTimeout(timerId) // 每当用户输入的时候把前一个 setTimeout clear 掉
// 然后又创建一个新的 setTimeout, 这样就能保证输入字符后的 interval 间隔内如果还有字符输入的话,就不会执行 fn 函数
timerId = setTimeout(() => {
fn.apply(this, arguments)
}, ms)
}
}

二、节流
节流: 高频事件触发,但在n秒内只会执行一次,所以节流会稀释函数的执行频率。
思路:每次触发事件时都判断当前是否有等待执行的延时函数。
使用的本质:允许某一行为触发,但是触发的频率不能太高。节流一般用于动画相关的场景。

实现方法:可以借助react的ahooks库的useThrottle或者是lodash库中的_.throttle来节流

原生:

function throttle(fn, ms) {
let timerId // 创建一个标记用来存放定时器的id
return function () {
// 没有定时器等待执行,则表示可以创建新的定时器来执行函数
if (!timerId) {
timerId = setTimeout(() => {
// 定时器id清空,表示可以执行下一次调用了
timerId = null
fn.apply(this, arguments)
}, ms)
}
}
}


http://www.niftyadmin.cn/n/212471.html

相关文章

Linux Shell 实现一键部署二进制docker+docker_compose

docker 前言 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows 机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。 d…

jquery :eq选择器和eq()方法的用法与比较

:eq(index) 匹配一个给定索引值的元素 index:从 0 开始计数 $("ul li:eq(3)") // 元素的index位置工0开始计数,所以这里的3实际为第4个元素 $("ul").find("li").eq(3) //使用jquery遍历方法eq() eq(index|-index) …

回收站清空了怎么恢复?快来get实用方法!

案例:回收站清空了怎么恢复? 【真的栓Q了,我刚点击回收站,不知道按错了什么,回收站被清空了,大家有什么方法可以恢复回收站里的文件吗?请大家给我出出主意吧!谢谢啦!】 …

vite+vue3基础

vite创建项目指令 npm create vitelatest . 项目创建选择vue。 创建完成之后安装依赖 npm i || cnpm ivite项目下 引入文件需要配置路径 //如果文件路径 .///如果文件层 较深 配置 “/***”“../../”配置vite中的 路径(js版本支持node全局变量 ts版本不支持 types…

Python算法设计|二分查找

版权声明:原创不易,本文禁止抄袭、转载,侵权必究! 目录一、二分查找二、算法思路三、Python算法实现四、作者Info一、二分查找 二分查找也被称为折半查找,是在一个有序数组中查找特定元素位置的查找算法。二分查找要求…

六、Locust之TaskSets详解

​ TaskSets是一种结构化测试分层网站/系统的方法。你可以在这里阅读更多关于它的信息。 1.TaskSet class ​ 如果你正在对一个以分层方式构建的网站进行性能测试,有章节和子章节,以同样的方式构建你的负载测试可能是有用的。 ​ 为了这个目的&#x…

Meta AI最新出品,全能的分割模型SAM:掀桌子的Segment Anything,CV届的ChatGPT已经到来!

掀桌子的Segment Anything 本来不打算再发关于分割的相关内容的,但是13小时前,2023年4月5号,Meta AI在Arxiv网站发布了文章《Segment Anything》,并将SAM模型代码和数据开源。作为通用的分割网络,SAM或许将成为&#…

笙默考试管理系统-club(1)

笙默考试管理系统-club(2) 目录 一、笙默考试管理系统-club 二、笙默考试管理系统-club 三、笙默考试管理系统-club 四、笙默考试管理系统-club 一、笙默考试管理系统-club function reply(id, o) { $("#rbox" id).toggle(); retur…