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

React ahooks——副作用类hooks之useThrottleFn

useThrottleFn 用于创建一个节流函数,确保该函数在指定时间内最多执行一次。

一、基本使用

import { useThrottleFn } from 'ahooks';
import { Button, Space } from 'antd';const ThrottleDemo = () => {const { run, cancel, flush } = useThrottleFn((message) => {console.log(message, new Date().toISOString());},{ wait: 2000,leading: true,trailing: true });return (<Space><Button onClick={() => run('常规调用')}>触发节流函数</Button><Button onClick={cancel}>取消待执行</Button><Button onClick={flush}>立即执行待调用</Button></Space>);
};

二、参数说明

2.1 配置项

useThrottleFn 的第二个参数是一个配置对象,可以设置以下选项:

主要配置项

  • wait (number)

    • 节流等待时间,单位毫秒

    • 默认值:1000 (1秒)

    • 示例:{ wait: 500 } 表示500毫秒内最多执行一次

  • leading (boolean)

    • 是否在节流开始前立即执行函数

    • 默认值:true

    • 如果设为 false,第一次调用不会立即执行

  • trailing (boolean)

    • 是否在节流结束后执行函数

    • 默认值:true

    • 如果设为 false,最后一次调用不会在延迟结束后执行

高级配置项

  • maxWait (number)

    • 最大等待时间,保证在超过此时间后一定会执行一次

    • 示例:{ wait: 500, maxWait: 2000 } 表示即使持续触发,至少每2秒会执行一次

2.2 返回值

run (Function)

  • 触发执行节流函数的入口

  • 调用时会根据配置的节流规则决定是否执行原函数

  • 可以传递参数给原函数

cancel (Function)

  • 取消所有待执行的节流函数调用

  • 清空节流计时器

flush (Function)

  • 立即执行当前待执行的节流函数(如果有)

  • 不会重置节流计时器

http://www.xdnf.cn/news/1229509.html

相关文章:

  • React ahooks——副作用类hooks之useDebounceFn
  • Shell【脚本 02】离线安装配置Zookeeper及Kafka并添加service服务和开机启动(脚本分析)
  • 堆----1.数组中的第K个最大元素
  • 通过filezilla在局域网下实现高速传输数据
  • 2025-08 安卓开发面试拷打记录(面试题)
  • 【龙泽科技】汽车故障诊断仿真教学软件【风光580】
  • Vue 详情模块 4
  • Python科研数据可视化技术
  • 知识蒸馏 - 基于KL散度的知识蒸馏 HelloWorld 示例
  • 在 AKS 中运行 Azure DevOps 自托管代理-2
  • 线程池的实现
  • 能力显著性向量:验证损失与下游能力的缩放定律
  • k8s使用 RBAC 鉴权
  • 如何在 Ubuntu 24.04 或 22.04 LTS Linux 上安装 Guake 终端应用程序
  • Allegro降版本工具
  • 学习笔记:无锁队列的原理以及c++实现
  • C# 中抽象类、密封类、静态类和接口的区别
  • Qt 信号和槽正常连接返回true,但发送信号后槽函数无响应问题【已解决】
  • WinForm之ListBox 控件
  • Qt 槽函数被执行多次,并且使用Qt::UniqueConnection无效【已解决】
  • 电子电气架构 --- 汽车网络安全概述
  • Java高性能编程实践指南
  • cv弹窗,退款确认弹窗
  • Java中Lambda 表达式的解释
  • 【AI】AIService(基本使用与指令定制)
  • 操作系统:远程过程调用( Remote Procedure Call,RPC)
  • 公网服务器上Nginx或者Openresty如何屏蔽IP直接扫描
  • java中的synchronized关键字​
  • 福彩双色球第2025088期篮球号码分析
  • PyTorch 张量核心操作——比较、排序与数据校验