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:函数返回值可以是任意类型。
相关推荐
林深现海几秒前
Jetson Orin nano/nx刷机后无法打开chrome/firefox浏览器
前端·chrome·firefox
EchoEcho12 分钟前
深入理解 Vue.js 渲染机制:从声明式到虚拟 DOM 的完整实现
vue.js
黄诂多14 分钟前
APP原生与H5互调Bridge技术原理及基础使用
前端
前端市界17 分钟前
用 React 手搓一个 3D 翻页书籍组件,呼吸海浪式翻页,交互体验带感!
前端·架构·github
文艺理科生19 分钟前
Nginx 路径映射深度解析:从本地开发到生产交付的底层哲学
前端·后端·架构
千寻girling19 分钟前
主管:”人家 Node 框架都用 Nest.js 了 , 你怎么还在用 Express ?“
前端·后端·面试
C澒28 分钟前
Vue 项目渐进式迁移 React:组件库接入与跨框架协同技术方案
前端·vue.js·react.js·架构·系统架构
清山博客1 小时前
OpenCV 人脸识别和比对工具
前端·webpack·node.js
要加油哦~1 小时前
AI | 实践教程 - ScreenCoder | 多agents前端代码生成
前端·javascript·人工智能
程序员Sunday1 小时前
说点不一样的。GPT-5.3 与 Claude Opus 4.6 同时炸场,前端变天了?
前端·gpt·状态模式