vue实现在一个方法执行完后执行另一个方法的示例


Posted in Javascript onAugust 25, 2018

用Promise来实现

function2(){
  // 你的逻辑代码 
  return Promise.resolve(/* 这里是需要返回的数据*/)
}

function3(){
  // 你的逻辑代码 
  return Promise.resolve(/* 这里是需要返回的数据*/)
}

// 调用
function1(){
  this.function2().then(val => { 
    this.function3();
  });
}

拓展知识:vue解决一个方法同时发送多个请求的问题

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

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

一般处理方法,就是点击的时候,立刻将该按钮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实现在一个方法执行完后执行另一个方法的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
如何快速的呈现我们的网页的技巧整理
Jul 01 Javascript
IE浏览器下PNG相关功能
Jul 05 Javascript
浅谈javascript中return语句
Jul 15 Javascript
node中koa中间件机制详解
Aug 22 Javascript
react-native fetch的具体使用方法
Nov 01 Javascript
jQuery实现动态添加节点与遍历节点功能示例
Nov 09 jQuery
微信小程序外卖选购页实现切换分类与数量加减功能案例
Jan 15 Javascript
vue-cli和v-charts实现可视化图表过程解析
Oct 08 Javascript
JS自定义滚动条效果
Mar 13 Javascript
Electron整合React使用搭建开发环境的步骤详解
Jun 07 Javascript
如何用JS实现网页瀑布流布局
Apr 24 Javascript
gojs实现蚂蚁线动画效果
Feb 18 Javascript
JS Object.preventExtensions(),Object.seal()与Object.freeze()用法实例分析
Aug 25 #Javascript
对Vue beforeRouteEnter 的next执行时机详解
Aug 25 #Javascript
vue 监听键盘回车事件详解 @keyup.enter || @keyup.enter.native
Aug 25 #Javascript
Vue中div contenteditable 的光标定位方法
Aug 25 #Javascript
Vue中mintui的field实现blur和focus事件的方法
Aug 25 #Javascript
vue-auto-focus: 控制自动聚焦行为的 vue 指令方法
Aug 25 #Javascript
解决vue+element 键盘回车事件导致页面刷新的问题
Aug 25 #Javascript
You might like
php 从数据库提取二进制图片的处理代码
2009/09/09 PHP
PHP中把对象数组转换成普通数组的方法
2015/07/10 PHP
Symfony2学习笔记之插件格式分析
2016/03/17 PHP
php 如何获取文件的后缀名
2016/06/05 PHP
跨浏览器的设置innerHTML方法
2006/09/18 Javascript
js 表单验证方法(实用)
2009/04/28 Javascript
javascript ready和load事件的区别示例介绍
2013/08/30 Javascript
jQuery满屏焦点图左右滚动特效代码分享
2015/09/07 Javascript
javascript html5 canvas实现可拖动省份的中国地图
2016/03/11 Javascript
原生js制作日历控件实例分享
2016/04/06 Javascript
Node.js中的require.resolve方法使用简介
2017/04/23 Javascript
一个简易的js图片轮播效果
2017/07/22 Javascript
JQ图片文件上传之前预览功能的简单实例(分享)
2017/11/12 Javascript
Angularjs Ng_repeat中实现复选框选中并显示不同的样式方法
2018/09/12 Javascript
NodeJS 将文件夹按照存放路径变成一个对应的JSON的方法
2018/10/17 NodeJs
新年快乐! javascript实现超级炫酷的3D烟花特效
2019/01/30 Javascript
ES6基础之字符串和函数的拓展详解
2019/08/22 Javascript
vue项目打包后请求地址错误/打包后跨域操作
2020/11/04 Javascript
微信小程序实现点赞业务
2021/02/10 Javascript
Python中的异常处理简明介绍
2015/04/13 Python
python中hasattr()、getattr()、setattr()函数的使用
2019/08/16 Python
如何使用Python脚本实现文件拷贝
2019/11/20 Python
logging level级别介绍
2020/02/21 Python
numpy矩阵数值太多不能全部显示的解决
2020/05/14 Python
Python包和模块的分发详细介绍
2020/06/19 Python
使用SimpleITK读取和保存NIfTI/DICOM文件实例
2020/07/01 Python
aec加密 php_php aes加密解密类(兼容php5、php7)
2021/03/14 PHP
瑞典廉价机票预订网站:Seat24
2018/06/19 全球购物
俄罗斯有趣和原创礼物网上商店:MagicMag
2019/08/01 全球购物
装修致歉信
2014/01/15 职场文书
数学与统计学院学生个人职业生涯规划书
2014/02/10 职场文书
实习推荐信
2014/05/10 职场文书
python实现A*寻路算法
2021/06/13 Python
Python实现制作销售数据可视化看板详解
2021/11/27 Python
Pytorch中使用ImageFolder读取数据集时忽略特定文件
2022/03/23 Python
Python时间操作之pytz模块使用详解
2022/06/14 Python