我的编程空间,编程开发者的网络收藏夹
学习永远不晚

react简单实现防抖和节流

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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)
         }
     }
 }

到此这篇关于react简单实现防抖和节流的文章就介绍到这了,更多相关react 防抖和节流内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

react简单实现防抖和节流

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

js如何实现防抖和节流

这篇文章给大家分享的是有关js如何实现防抖和节流的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。防抖 & 节流防抖和节流属于高阶技巧,业务中比较多见的场合也就是搜索内容改变提示信息。即使不加也也不一定能看出区别,但
2023-06-27

JavaScript的防抖和节流怎么实现

这篇文章主要介绍了JavaScript的防抖和节流怎么实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JavaScript的防抖和节流怎么实现文章都会有所收获,下面我们一起来看看吧。1. 前言首先来举个例子。
2023-06-29

JS中节流和防抖怎么实现

本篇内容主要讲解“JS中节流和防抖怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“JS中节流和防抖怎么实现”吧!引言在前端开发中,经常和DOM、BOM打交道,例如:窗口的resize、sc
2023-07-02

JavaScript如何实现防抖与节流

这篇文章主要介绍了JavaScript如何实现防抖与节流,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。概念防抖:点击N次提交按钮,只有最后一次会发出请求。减少无效请求的次数。
2023-06-29

Vue 2中实现CustomRef方式防抖节流

这篇文章主要为大家介绍了Vue 2中实现CustomRef方式防抖节流示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-02-12

Vue使用lodash进行防抖节流的实现

本文主要介绍了Vue使用lodash进行防抖节流的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
2023-05-15

js防抖-节流函数的基本实现和补充详解

这篇文章主要介绍了防抖-节流函数的基本实现和补充,文章从基础概念到手写对防抖-节流函数的实现进行讲解,内容详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
2023-01-08

vue3+ts如何通过lodash实现防抖节流详解

loadsh是一个工具库,我们通常使用loadsh的debounce函数处理防抖,下面这篇文章主要给大家介绍了关于vue3+ts如何通过lodash实现防抖节流的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
2022-11-13

JS防抖节流函数的实现与使用方式

本篇内容介绍了“JS防抖节流函数的实现与使用方式”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!目录一、什么是函数防抖1、为什么需要函数防抖?
2023-06-20

编程热搜

目录