Vue3 自定义指令封装实现防抖 防止按钮暴力点击

本来项目前期没有做按钮防抖功能 快结束时才想起来 然后一个个写太慢了 然后就想着封装一下

新建 directive.js

复制代码
export default {
    //自定义节流操作
    preventReClick: {
        mounted(el, binding) {
            el.addEventListener('click', () => {
                if (!el.disabled) {
                    el.disabled = true
                    setTimeout(() => {
                        el.disabled = false
                    }, binding.value || 2000) //2000ms间隔时间
                }
            })
        }
    }
}

然后在全局注册指令

复制代码
// 点击防抖注册
import dir from '../src/utils/directive'
const app = createApp(App);
app.directive('preventReClick', dir.preventReClick);

最后使用的时候 v-preventReClick如果不指定延迟时间 会默认为设置的2000

复制代码
<el-button v-preventReClick="500" type="primary" @click="login()">登录</el-button>

注: 这个只对饿了吗组件库的按钮类点击事件管用

如果是div一类的点击事件 用下面常用的方法把

复制代码
// 表情评分防抖实现
const debouncedUpdateCount = function (id, item, num) {
    if (debounceTimeout.value) {
        clearTimeout(debounceTimeout.value);
    }
    debounceTimeout.value = setTimeout(() => {
        updateCount(id, item, num);
    }, 500); // 调整延迟时间(毫秒)
};


const updateCount = (id,item,num) =>{
        /你的逻辑
    }



  <div @click="debouncedUpdateCount(item.id,item,1)" :class="{ selected: item.count == 1 }">
    <img src="../../assets/icons/garid1.png" alt="">
    <span>很差1分</span>
 </div>
相关推荐
我想回家种地几秒前
python期末复习重点
前端·javascript·python
行者963 分钟前
Flutter适配OpenHarmony:高效数据筛选组件的设计与实现
开发语言·前端·flutter·harmonyos·鸿蒙
Van_Moonlight7 分钟前
RN for OpenHarmony 实战 TodoList 项目:底部 Tab 栏
javascript·开源·harmonyos
Van_Moonlight9 分钟前
RN for OpenHarmony 实战 TodoList 项目:浮动添加按钮 FAB
javascript·开源·harmonyos
Serendipity-Solitude12 分钟前
HTML 五子棋实现方法
前端·html
frontend_frank12 分钟前
脱离 Electron autoUpdater:uni-app跨端更新:Windows+Android统一实现方案
android·前端·javascript·electron·uni-app
PieroPC14 分钟前
用FastAPI 一个 后端 和 两个前端 原生HTML/CSS/JS 、Vue3 写一个博客系统 例
前端·后端
wulijuan88866616 分钟前
BroadcastChannel API 同源的多个标签页可以使用 BroadcastChannel 进行通讯
前端·javascript·vue.js
kilito_0121 分钟前
数字时钟翻页效果
javascript·css·css3
Van_Moonlight22 分钟前
RN for OpenHarmony 实战 TodoList 项目:今日任务数量统计
javascript·开源·harmonyos