Vue全局事件防止重复点击(等待请求)【进阶版】

本文介绍了如何通过Vue全局混入的方式,更简洁地在组件上绑定click事件,并处理同步和异步回调,同时保持组件状态管理的灵活性。
摘要由CSDN通过智能技术生成

《Vue全局指令防止重复点击(等待请求)》之后,感觉指令方式还是不太友好,而且嵌套闭包比较麻烦,于是想到了Vue的全局混入,利用混入,给组件绑定click事件。

一、实现原理

与指令方式大致一样,只不过事件方式则是利用组件的事件监听属性完成绑定,这种方式更加友好、简洁、易懂。

二、使用

<el-button type="primary" icon="el-icon-search" size="mini" @conClick="handleQuery">搜索</el-button>

三、注意事项

1. 同步和异步回调

当前方式同样支持同步和异步回调,且异步回调需闭包

同步:

handleQuery() {
  this.queryParams.pageNum = 1;
  await this.getList();
}

异步回调:

handleQuery() {
  return (removeDisabled) => {
    // 去掉组件禁用
    removeDisabled();
  }
}

四、代码

import Vue from 'vue'

Vue.mixin({
  mounted() {
    // 获取组件所有的监听事件,判断有没有conClick
    if (this.$listeners && this.$listeners.conClick && this.$listeners.conClick instanceof Function) {
      // 如果有的话给对应的DOM添加click监听
      const el = this.$el;
      el.addEventListener('click', async (e) => {
        // 自定义点击开始DOM状态
        let hasCb = false;
        el.classList.add('is-disabled');
        el.disabled = true;

        // 执行组件绑定的事件
        const res = await this.$listeners.conClick();
        if (res instanceof Function) {
          // 如果获取的结果为方法,则为异步回调
          hasCb = true;
          const d = res(() => {
            el.disabled = false;
            el.classList.remove('is-disabled');
          })
          if (!(d instanceof Promise)) {
            hasCb = true;
          } else {
            await d;
          }
        }

        // 自定义点击结束DOM状态
        if (!hasCb) {
          el.disabled = false;
          el.classList.remove('is-disabled');
        }
      });
    }
  }
})
  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vue3中,你可以通过全局指令来实现全局点击事件全局指令可以在所有的.vue文件中使用。你可以在main.js文件中定义全局指令,或者在一个单独的js文件中定义并在main.js中引入。下面是一个在main.js中定义全局点击事件的例子: ```javascript import { createApp } from 'vue'; import App from './App.vue'; const app = createApp(App); app.directive('onceClick', { mounted(el, binding, vnode) { el.addEventListener('click', () => { if (!el.disabled) { el.disabled = true; setTimeout(() => { el.disabled = false; }, binding.value || 1000); } }); } }); app.mount('#app'); ``` 在这个例子中,我们通过app.directive方法定义了一个名为onceClick的全局指令。在mounted函数中,我们给元素添加了一个点击事件监听器,当元素被点击时,会执行一段逻辑来禁用按钮一段时间。你可以根据自己的需求来修改这段逻辑。然后,我们通过app.mount方法将应用程序挂载到#app元素上。 这样,你就可以在任何一个.vue文件中使用onceClick指令来实现全局点击事件了。例如: ```vue <template> <div> <button v-onceClick="10000" @click="btnClick">Click Me</button> </div> </template> <script> export default { setup() { const btnClick = () => { // 点击按钮的逻辑 } return { btnClick } } } </script> ``` 在上面的例子中,我们在按钮上使用了onceClick指令,指定了一个延迟时间为10000毫秒。当按钮被点击后,会执行btnClick方法中的逻辑。 希望这个例子能够帮助到你!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Vue3 自定义指令](https://blog.csdn.net/m0_62758542/article/details/128544406)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

会功夫的李白

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值