在项目开发过程中,让人抓狂之一的问题就是一个点击事件,当快速点击的时候,它会重复发送多个请求。这是不允许出现的。

但是怎么解决这个问题呢?

一般处理方法,就是点击的时候,立刻将该按钮disabled,这样就可以避免重复发送请求了。但是我发现这个有一个弊端,那就是:

如果,该事件有许多的验证,比如电话、邮箱格式是否正确呀,必填的是否填了呀等等。一旦你点击就把按钮disabled了,发现该填的没填,回去填完后发现按钮不能点了?那是因为刚才点击的时候被你disabled了,所以还得在验证的方法中取消按钮的disable。就造成了你点击的时候,第一步,将按钮disable了,然后一步一步向下验证,如果验证出错,得取消disable,当所有验证通过了,在请求的回调函数中,成功了也要取消disable,失败了也要取消disable,因为失败了用户多半还会继续点两次,不取消disable会让用户发现怎么点不了了。这就造成了全篇都是按钮disable的设置与取消。一旦有修改,很难维护的。

在vue中,有一个lodash,我们只需引入就可以使用了。比如以下代码:

<template><div><div class="bindBtn"><button class="bindDataBtn" @click="postAction">提交</button></div></div>
</template>
<script>
import _ from 'lodash'
export default {data() {return {}},mounted() {},methods: {sendAjax(){/*这里是请求的接口、参数以及回调函数等*/},postAction(){this.doPostAction()}},created(){this.doPostAction = _.debounce(this.sendAjax,500);}
}
</script>

我们首先将发送请求的ajax方法写在一个函数里面,在这里就是sendAjax函数,其次,我们引入lodash,然后将sendAjax这个函数用一个方法自定义一下,在这里就是doPostAction,其中_是我们引入的lodash,_.debounce是一个限制操作频率的函数,里面的是500是毫秒单位。

当执行点击事件的时候,也就是postAction函数,我们只需要调用doPostAction这个函数就可以了,而那个500的功能就是你在这个时间段里,无论执行了多少次这个点击事件,它都只会执行一次。

这样就少了我们通篇disable来disable去

最后附上官网例子:点击前往

vue解决一个方法同时发送多个请求相关推荐

  1. 在springmvc中controller的一个方法处理多个不同请求

    value的uri值为以下三类: A) 可以指定为普通的具体值: B)  可以指定为含有某变量的一类值(URI Template Patterns with Path Variables): @Req ...

  2. java使用POST发送soap报文请求webservice返回500错误解析

    本文使用JAX-WS2.2编译webservice,并使用HttpUrlConnection的POST方式对wsdl发送soap报文进行请求返回数据, 对错误Server returned HTTP ...

  3. 一个Https网站发送Http的 ajax请求的解决方法

    一个Https网站发送Http的 ajax请求的解决方法 参考文章: (1)一个Https网站发送Http的 ajax请求的解决方法 (2)https://www.cnblogs.com/yuming ...

  4. vue在一个方法执行完后执行另一个方法

    vue在一个方法执行完后执行另一个方法 用Promise来实现. Promise是ES6的新特性,用于处理异步操作逻辑,用过给Promise添加then和catch函数,处理成功和失败的情况 ES7中 ...

  5. Vue通过Axios向后台发送Post请求,浏览器Console提示405,后台显示Get请求不支持--解决办法

    Vue通过Axios向后台发送Post请求,浏览器Console提示405,后台显示Get请求不支持–解决办法 问题场景: axios默认是发送get请求,我要给后台发送一组用户填写的表单数据,逻辑简 ...

  6. ASP.NET一般处理程序新建一个方法里使用context.Response.Write的解决方法

    ASP.NET一般处理程序新建一个方法里使用context.Response.Write的解决方法 参考文章: (1)ASP.NET一般处理程序新建一个方法里使用context.Response.Wr ...

  7. 解决:vue 用 axios 发送请求,每次都会发送两次请求

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 我的解决方法是后端加一个过滤器: package gentle.filter;import java ...

  8. vue学习笔记之:为何data是一个方法

    vue学习笔记之:为何data是一个方法 在vue开发中,我们可以发现,data中的属性值是在function中return出来的.可为何data必须是一个函数呢?我们先看官方的解释: 当一个组件被定 ...

  9. 在同一个类中,一个方法调用另外一个有注解(比如@Async,@Transational)的方法,注解失效的原因和解决方法

    在同一个类中,一个方法调用另外一个有注解(比如@Async,@Transational)的方法,注解失效的原因和解决方法 参考文章: (1)在同一个类中,一个方法调用另外一个有注解(比如@Async, ...

最新文章

  1. 大系统观:第2章 系统论概述
  2. 定制iOS 7中的导航栏和状态栏
  3. 我的机器人现在无处可去。 无家可归。 无服务器。
  4. 学习《css世界》笔记之使用css实现凹凸效果
  5. [你必须知道的.NET] 第三回:历史纠葛:特性和属性
  6. Diango博客--12.开发 Django 博客文章阅读量统计功能
  7. Chrome 96 又更新了 5 个巨巨巨好用的功能
  8. Centos7 配置网络
  9. 安卓模拟器怎么切换IP地址
  10. 联想y50更换固态硬盘_联想y50怎么加固态硬盘而不换原来的机器硬盘?
  11. php公物管理系统,开源客户管理系统 fly-crm
  12. 动态规划之矩阵连乘问题详细解读(思路解读+填表+代码)
  13. OPC DA 服务端搭建 (附Java 客户端代码)
  14. 算法快学笔记(一):算法入门
  15. 【已解决】U盘文件误删 恢复,实用有效 免费无充值 Recuva
  16. 勒索病毒爆发波及中石油:2万座加油站断网
  17. PLC单片机实验开发设备
  18. MySQL的存储过程(in、out、inout)
  19. html图片菱形,CSS3 菱形拼图实现只旋转div 背景图片不旋转功能
  20. 分布式存储系统 Ceph 介绍与环境部署

热门文章

  1. 字体模糊是怎么回事css,CSS3 translate导致字体模糊怎么办 CSS3 translate导致字体模糊解决方法...
  2. 机器学习方法之神经网络(NN)
  3. 聊一聊ChatGPT
  4. 建网站建设的目的是什么?为什么要建网站建设?
  5. 使用Photoshop合成两张不完整的图片
  6. Windows系统kernel32.dll文件出问题的原因及其解决方案
  7. [示例] 迅雷看看播放完成后自动关机
  8. DiskGenius 中文硬盘分区表维护软件
  9. 劳动合同试用期规定多久
  10. 浅谈C/C++文件流的操作