vue3实现防抖hook

vue3实现防抖hook

包装函数并延迟执行,避免频繁触发,常用于前端页面搜索框优化处理(只在输入停止的时候才去执行相应的操作)

src/hook/useDebounce.ts

javaScript 复制代码
import { ref, watch } from 'vue';

/**
 * 防抖 Hook
 * @param fn - 需要防抖的函数
 * @param delay - 延迟时间(毫秒),默认300ms
 * @returns 包含防抖函数和清除定时器的方法
 */
export function useDebounce<T extends (...args: any[]) => any>(
  fn: T,
  delay: number = 300
) {
  // 存储定时器ID
  const timer = ref<NodeJS.Timeout | null>(null);

  // 防抖处理函数,保持原函数的参数类型
  const debouncedFn = (...args: Parameters<T>): void => {
    // 清除已有定时器
    if (timer.value) {
      clearTimeout(timer.value);
    }

    // 设置新定时器
    timer.value = setTimeout(() => {
      fn.apply(this, args);
      timer.value = null;
    }, delay);
  };

  // 组件卸载时清除定时器,防止内存泄漏
  watch(
    () => {},
    () => {
      if (timer.value) {
        clearTimeout(timer.value);
      }
    },
    { once: true }
  );

  // 手动清除定时器的方法
  const clearDebounce = (): void => {
    if (timer.value) {
      clearTimeout(timer.value);
      timer.value = null;
    }
  };

  return { debouncedFn, clearDebounce };
}
    

应用

javaScript 复制代码
import { ref } from "vue";
import { useDebounce } from "@/hook/useDebounce";
const handleSearch = keyword => {
  console.log("搜索:", keyword);
  // 实际的搜索逻辑...
};
// 在输入框变化时调用防抖函数、使用防抖Hook,延迟500ms
const { debouncedFn: debouncedSearch } = useDebounce(handleSearch, 500);
javaScript 复制代码
      <el-input
        v-model="searchValue"
        placeholder="请输入内容"
        @input="debouncedSearch"
      />

其他

  • ref<NodeJS.Timeout | null>(null)

    • ref :Vue3 提供的创建响应式数据的函数,会将传入的值包装为一个响应式对象(Ref 类型),方便在组件中追踪其变化。

    • <NodeJS.Timeout | null> :TypeScript 的类型注解,指定 ref 存储的值类型只能是两种之一:

      • NodeJS.Timeout:Node.js 环境中定时器的类型(setTimeout 的返回值类型),表示一个活跃的定时器实例。
      • null:表示没有活跃的定时器(初始状态或定时器已被清除)。
    • (null) :初始化 ref 的值为 null,即初始状态下没有定时器。

  • T extends (...args: any[]) => any

    • 是 TypeScript 中的泛型约束 ,用于限制泛型 T 的类型范围,具体含义如下:

拆解说明:

  • T:是定义的泛型变量,代表 "某种类型",具体类型会在使用时动态确定。

  • extends:泛型约束关键字,表示 "T 必须是某种类型的子类型"。

  • (...args: any[]) => any:一个函数类型的 "模板",表示:

    • (...args: any[]):函数可以接收任意数量、任意类型的参数(args 是参数数组)。
    • => any:函数返回值可以是任意类型。
相关推荐
可别3907 分钟前
使用Worker打包报错
前端·vue.js
GIS瞧葩菜12 分钟前
【无标题】
开发语言·前端·javascript·cesium
T___T17 分钟前
彻底搞懂 CSS 盒子模型 box-sizing:小白也能看懂的布局核心
前端·面试
彭于晏爱编程20 分钟前
关于表单,别做工具库舔狗
前端·javascript·面试
空白格9720 分钟前
Android插件化开发
前端
风中凌乱的L22 分钟前
vue canvas标注
前端·vue.js·canvas
拉不动的猪23 分钟前
什么是二义性,实际项目中又有哪些应用
前端·javascript·面试
海云前端125 分钟前
Webpack打包提速95%实战:从20秒到1.5秒的优化技巧
前端
烟袅30 分钟前
LeetCode 142:环形链表 II —— 快慢指针定位环的起点(JavaScript)
前端·javascript·算法
梦65034 分钟前
什么是react?
前端·react.js·前端框架