React ahooks——副作用类hooks之useThrottleFn

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

一、基本使用

javascript 复制代码
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)

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

  • 不会重置节流计时器

相关推荐
kong@react16 小时前
react+ts项目,富文本开发(wangEditor)
前端·react.js·前端框架
重铸码农荣光16 小时前
AI First + Mobile First:用大模型重构下一代应用开发范式
前端·架构·llm
Lovely_Ruby17 小时前
前端er Go-Frame 的学习笔记:实现 to-do 功能(二),前端项目的开发,对接后端
前端
willingtolove17 小时前
使用chrome修改请求参数重新发送请求
前端·chrome
-曾牛17 小时前
CSRF跨站请求伪造:原理、利用与防御全解析
前端·网络·web安全·网络安全·渗透测试·csrf·原理解析
卓码软件测评17 小时前
第三方软件检测机构:【利用测试工具Postman测试沙箱:在Tests标签中编写健壮的质量检查逻辑测试脚本】
javascript·node.js·postman
魂祈梦17 小时前
前端下载多个文件/浏览器批量下载文件
前端·浏览器
谎言西西里17 小时前
彻底搞懂 JavaScript 的 this:从陷阱到解决方案
javascript
小明记账簿_微信小程序17 小时前
手写一个webpack插件(plugin)
前端
我命由我1234518 小时前
微信小程序 - scroll-view 的一些要点(scroll-view 需要设置滚动方向、scroll-view 需要设置高度)
开发语言·前端·javascript·微信小程序·小程序·前端框架·js