防止连续点击按钮,多次调用接口

防止连续点击按钮,导致多次调用接口问题

文章目录


一、为什么需要禁止按钮多次调用问题?

因为在很多场景下,都会新增一些案例,如果允许可以多次调用就会出现新增多条同样的数据,还有就是在工作人员操作下会不小心多次点击导致多条同样的数据,会引起误解,因此需要防止连续点击新增/保存按钮多次

二、实现步骤

1.使用Vue.directive 自定义指令

使用自定义指令的好处就是方便简洁,还有就是用的地方比较多,不用到处引入文件,创建一个文件后缀为xxx.js

js 复制代码
export default {
  install(Vue) {
    // 防止重复点击preventMoreClick 就是自定义命令的名称
    Vue.directive('preventMoreClick', {
      inserted(el, binding) {
      // 监听事件
        el.addEventListener('click', () => {
          if (!el.disabled) {
            el.disabled = true;
            // 给一个定时器点一次需要多久才可以点从而实现了这个功能
            setTimeout(() => {
              el.disabled = false;
            }, 2000);
          }
        });
      }
    });
  }
};

2.在入口文件main.js引入文件

代码如下(示例):

js 复制代码
j// XXX就是文件名称
import XXX from 'xxx.js';
Vue.use(XXX );

2.使用自定义指令

html 复制代码
<el-button @click='handleClick' v-preventMoreClick>点击这里</el-button>

总结

提示:这里对文章进行总结:

例如:以上就是今天要讲的内容,就是为简单的简述了自定义指令的用法

相关推荐
jvxiao5 小时前
你真的懂作用域吗?从编译原理角度深度 JS 的作用域
前端·javascript
Darling噜啦啦5 小时前
二叉树与递归算法实战:从树结构到 LeetCode 爬楼梯,一文吃透前端数据结构与递归思维
前端·javascript·数据结构
星栈5 小时前
Rust + Makepad 应用怎么打包发布:Windows、macOS、Linux 全平台交付
前端·rust
Aolith5 小时前
React 路由守卫:我用一个组件替代了 Vue 的 beforeEach
前端·react.js
Daybreak5 小时前
从 PDD、DDD、SDD 到 TDD:我是如何用一套 Agent 工程方法论推进 My-Notion 的
前端
HjhIron6 小时前
从零实现一个待办事项应用:前端必学的Ajax与Node.js实战
前端·后端
yingyima6 小时前
JavaScript 正则表达式:从零开始的实战对比
前端
xsbcme6 小时前
VueTabRouter 插件实践(一):多标签页不是一排 TabBar
vue.js
Sammyyyyy6 小时前
月之暗面 Kimi Code 0.4.0 发布,终端 AI 编码助手全面采用 TypeScript,实现毫秒级启动
前端·javascript·人工智能·ai·typescript·servbay
范什么特西6 小时前
配置文件xml和properties
xml·前端