当前位置: 首页 > article >正文

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

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

在日常开发中,我们经常会有这样的需求:监听用户的输入(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.kler.cn/news/9364.html

相关文章:

  • 用于平抑可再生能源功率波动的储能电站建模及评价(Matlab代码实现)
  • 【前端做项目常用】相关插件的官网 总结
  • 【web自动化测试】
  • LinuxGUI自动化测试框架搭建(七)-Ubuntu上安装配置Pycharm
  • windows 如何安装cuda pytorch gpu
  • 手动挡科目三道路驾驶技能考试及理论考试要点
  • 基于金豺优化算法python代码
  • 智慧停车怎么实现的,停车场寻车是怎么实现的
  • 网络编程初探
  • css 使用blur,实现背景色高斯模糊,但不影响背景上的内容
  • 【深度学习】深度学习中经常会被问到的知识点总结(1) | GPT记录
  • 游戏开发之Unity2021熟悉基本工具
  • Pandas 2.0正式版发布: Pandas 1.5,Polars,Pandas 2.0 速度对比测试
  • redis杂谈之部分重同步的实现
  • [ 云计算 | Azure ] Chapter 05 | 核心体系结构之管理组、订阅、资源和资源组以及层次关系
  • 数据结构-插入排序
  • 一、源码详解(第一阶段)
  • 面向对象编程(进阶)5:关键字:super
  • 数据传输控制方式
  • 【虹科案例】虹科脉冲发生器在读出电子测试中的应用
  • docker安装mysql+redis+nginx
  • 外卖小程序01
  • 什么是转化率优化(CRO)?网站转化率不高,可以看看这篇文章
  • 内存对齐总结
  • Java异常处理
  • 【AUTOSAR】【Lin通信】Lin
  • Java实验课的学习笔记(二)类的简单使用
  • 2023年,软件测试行业怎么样?
  • Spark 并行度
  • docker 安装redis