React ahooks——副作用类hooks之useDebounceFn

useDebounceFnahooks 提供的用于函数防抖的Hook,它可以确保一个函数在连续触发时只执行最后一次。

一、基本用法

javascript 复制代码
import { useDebounceFn } from 'ahooks';
import { Button } from 'antd';

const Demo = () => {
  const { run } = useDebounceFn(
    () => {
      console.log('防抖函数执行', new Date().toISOString());
    },
    {
    wait: 500,
    leading: true,   // 第一次立即执行
    trailing: true,  // 最后一次也执行
    maxWait: 2000   // 最多2秒必须执行一次
  }
  );

  return (
    <Button onClick={run}>
      点击我(防抖500ms)
    </Button>
  );
};

二、参数说明

2.1 输入参数

  • 第一个参数:需要防抖的函数

  • 第二个参数:配置对象

    • wait:防抖等待时间,单位毫秒(默认 1000ms)

    • leading:是否在延迟开始前立即执行(默认 false)

    • trailing:是否在延迟结束后执行(默认 true)

    • maxWait:最大等待时间(保证函数至少在这个时间内执行一次)

2.2 返回值

  • run:触发执行的防抖函数

  • cancel:取消当前防抖

  • flush:立即执行当前等待的函数

相关推荐
若梦plus2 分钟前
模块化与package.json
前端
烛阴7 分钟前
Aspect Ratio -- 宽高比
前端·webgl
若梦plus10 分钟前
Node.js中util.promisify原理分析
前端·node.js
gnip11 分钟前
滚动元素到可视区
前端·javascript
噫酱永不放弃12 分钟前
愈发简单的 JS 库开发
前端·rollup.js
若梦plus22 分钟前
Xata低代码服务器端数据库平台之技术分析
前端·后端
摆烂工程师23 分钟前
GPT-5 即将凌晨1点进行发布,免费用户可以使用 GPT-5
前端·人工智能·程序员
若梦plus24 分钟前
Xano低代码后端开发平台之技术分析
前端·后端
若梦plus28 分钟前
《深入 SystemJS:构建灵活解耦的前端模块体系》
前端
若梦plus32 分钟前
动作流执行引擎与工作流引擎
前端