首页 > Python资料 博客日记
react防抖和节流hooks封装
2024-08-02 21:00:11Python资料围观81次
文章react防抖和节流hooks封装分享给大家,欢迎收藏Python资料网,专注分享技术知识
一、防抖和节流概述
防抖(debounce)和节流(throttle)是前端经常用到的工具函数。
在进行窗口的resize、scroll,输入框内容校验等操作时,如果事件处理函数调用的频率无限制,会加重浏览器的负担,导致用户体验非常糟糕。此时我们可以采用debounce(防抖)和throttle(节流)的方式来减少调用频率,同时又不影响实际效果。
通常情况下,我们习惯于使用lodash
提供的工具函数,那么如何自己封装防抖节流的hooks?
首先了解下概念:
- 防抖: 维护一个计时器,规定在delay时间后触发函数,但是在delay时间内再次触发的话,就会取消之前的计时器而重新设置。这样一来,只有最后一次操作能被触发。
- 节流: 维护一个计时器,规定在delay时间后触发函数,但是在delay时间内再次触发的话,会判断是否有延迟调用函数未执行,有则返回,没有则设定在delay时间后触发函数
1、函数防抖
当持续触发事件时,一定时间段内没有再触发事件,事件处理函数才会执行一次,如果设定的时间到来之前,又一次触发了事件,就重新开始延时。
function debounce(fn, ms) {
let timer;
return function(...args) {
if (timer) {
clearTimeout(timer)
}
timer = setTimeout(() => {
fn(...args)
timer = null;
}, ms);
}
}
2、函数节流
当持续触发事件时,保证一定时间段内只调用一次事件处理函数。
function throttle(fn, ms) {
let timer;
return function(...args) {
if (timer) return;
canRun = false;
timer = setTimeout(() => {
fn(...args);
timer = null;
}, ms);
}
}
二、react当中防抖细节
防抖函数必须在只执行一次的位置调用。在类组件中,放在constructor
里或者变量函数生成的时候都可以,因为类组件只会初始化一次,后续组件中绑定的函数永远是不变的,因此依据闭包原理保存下来的状态会起作用。
而在函数式组件中,每次render时,内部函数会重新生成并绑定到组件上去。当组件只有一个state会影响render
时,我们
- 狂点按钮,
- 只会触发点击事件,不会重新渲染,
- 当前组件绑定的事件函数没有变化,防抖函数是同一个,因此防抖起作用
但是当有其他state
影响渲染后
- 狂点按钮
- 触发事件,不重新渲染
count2
发生变化,重新渲染- handleClick重新生成并绑定到组件,
- 原有函数失效,防抖失效,原有函数延迟一定后执行
counter1
发生变化
流程的对比就是这样了,现在你明白为什么正常的防抖函数不能用在 reack hook
里了么?
那么,怎么实现react hook
防抖呢?核心思想就是,保证每次渲染时,绑定到组件上的函数是同一个防抖函数。
防抖hook
import { useCallback, useEffect, useRef } from 'react';
export interface UseRefParams {
fn: (_args: any) => void;
timer: ReturnType<typeof setTimeout> | null;
}
// React anti shake function
export const useDebounce = (fn: (_args: any) => void, delay = 2000) => {
const { current } = useRef<UseRefParams>({ fn, timer: null });
useEffect(() => {
current.fn = fn;
}, [current, fn]);
return useCallback(
(args: any) => {
if (current.timer) {
clearTimeout(current.timer);
}
current.timer = setTimeout(() => {
current.fn(args);
}, delay);
},
[current, delay]
);
};
三 、节流Hook
在react当中节流注意细节与防抖一样,这里不做陈述,直接上代码:
import { useCallback, useEffect, useRef } from 'react';
export interface UseRefParams {
fn: (_args: any) => void;
timer: ReturnType<typeof setTimeout> | null;
}
// React throttling function
export const useThrottle = (fn: (_args: any) => void, delay = 2000) => {
const { current } = useRef<UseRefParams>({ fn, timer: null });
useEffect(
function () {
current.fn = fn;
},
[current, fn]
);
return useCallback(
function f(args: any) {
if (!current.timer) {
current.timer = setTimeout(() => {
current.timer = null;
}, delay);
current.fn(args);
}
},
[current, delay]
);
};
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
相关文章
最新发布
- 光流法结合深度学习神经网络的原理及应用(完整代码都有Python opencv)
- Python 图像处理进阶:特征提取与图像分类
- 大数据可视化分析-基于python的电影数据分析及可视化系统_9532dr50
- 【Python】入门(运算、输出、数据类型)
- 【Python】第一弹---解锁编程新世界:深入理解计算机基础与Python入门指南
- 华为OD机试E卷 --第k个排列 --24年OD统一考试(Java & JS & Python & C & C++)
- Python已安装包在import时报错未找到的解决方法
- 【Python】自动化神器PyAutoGUI —告别手动操作,一键模拟鼠标键盘,玩转微信及各种软件自动化
- Pycharm连接SQL Sever(详细教程)
- Python编程练习题及解析(49题)
点击排行
- 版本匹配指南:Numpy版本和Python版本的对应关系
- 版本匹配指南:PyTorch版本、torchvision 版本和Python版本的对应关系
- Python 可视化 web 神器:streamlit、Gradio、dash、nicegui;低代码 Python Web 框架:PyWebIO
- 相关性分析——Pearson相关系数+热力图(附data和Python完整代码)
- Anaconda版本和Python版本对应关系(持续更新...)
- Python与PyTorch的版本对应
- Windows上安装 Python 环境并配置环境变量 (超详细教程)
- Python pyinstaller打包exe最完整教程