vue3防抖函数封装与使用,以指令的形式使用

utils/debounce.js

javascript 复制代码
/**
 * 防抖函数
 * @param {*} fn 函数
 * @param {*} delay 暂停时间
 * @returns 
 */
export function debounce(fn, delay = 500) {
  
    let timer = null
    return function (...args) {
      // console.log(arguments);
      // const args = Array.from(arguments)
      if (timer) {
        clearTimeout(timer)
      }
      timer = setTimeout(() => {
        fn.apply(this, args)
      }, delay)
    }
  }

main.js 定义全局化指令

javascript 复制代码
import { createApp } from 'vue'
import App from './App.vue'
import { debounce } from './utils/debounce'

const app = createApp(App)

// 创建全局指令
app.directive('debounce', {
  mounted(el, binding) {
    const { value, arg } = binding
    const debouncedFn = debounce(value, arg)
    el.addEventListener('click', debouncedFn) // 将事件改为click
  },
  beforeUnmount(el, binding) {
    const { value } = binding
    el.removeEventListener('click', value)
  }
})

app.mount('#app')

指令的使用

复制代码
<template>
	<button v-debounce="handleInput" :delay="500">无参</button>
	<button v-debounce="() => handleInput2(1, 2)" :delay="500">传参</button>
</template>
<script>
	export default{
		methods: {
		    handleInput(){
		      console.log('防抖指令的使用');
		    },
		   handleInput2(v1, v2){
		      console.log('接收参数', v1,v2);
		    },
		}
	}
</script>
相关推荐
Funny Valentine-js4 分钟前
web实验后端php测试文本
前端·javascript·php·html5·cookie·telnet·session
DevUI团队24 分钟前
解锁前端高阶调试:浏览器/IDE/Git技巧分享
前端·javascript·html
August_._32 分钟前
【软件安装教程】Node.js 开发环境搭建详解:从安装包下载到全局配置,一篇搞定所有流程
java·vue.js·windows·后端·node.js·配置
一颗烂土豆32 分钟前
🚀从 autofit 到 vfit:Vue 开发者该选哪个大屏适配工具?
前端·vue.js
CoolerWu34 分钟前
Trae Solo 实战指南:从"会用"到"用好"的协作方法论
前端·javascript
鹏多多44 分钟前
轻量+响应式!React瀑布流插件react-masonry-css的详细教程和案例
前端·javascript·react.js
一颗宁檬不酸1 小时前
Vue.js 初学者基础知识点总结 第一弹
前端·javascript·vue.js
xiaoxue..1 小时前
解析 LocalStorage与事件委托在前端数据持久化中的应用
前端·javascript·面试
j***89461 小时前
MySQL数据的增删改查(一)
android·javascript·mysql
@cc小鱼仔仔1 小时前
vue 知识点
前端·javascript·vue.js