Vue中的同步和异步调用顺序详解

Vue中的同步和异步调用顺序详解

目录

Vue的同步和异步调用顺序

例如

Vue两个异步方法顺序执行

第一个异步方法

第二个异步方法

Vue的同步和异步调用顺序

Vue中的方法调用顺序是依次进行的,方法体内部也是依次执行的,但是,两个方法体的执行顺序并不能严格控制。

以下方法中都带有promise函数或异步调用。

    initUserData() {       this.getPsCountryList() // 1 获取国家列表stateOptions,方法内同步       this.getTimeZone() // 2 获取时区timezones,方法内同步       this.getUserInfo() // 3 获取用户信息     }

在实际运行中,三个方法的执行顺序是1-2-3,但是方法3始终不能获取到stateOptions和timezones

背后的调用顺序是1-2-3,但是,方法的执行时间并没有严格控制。

如果想要做到方法调用和执行是同步的,可以使用async和await修饰符。

例如     async initUserData() {       await this.getPsCountryList() // 1 获取国家列表stateOptions,方法内同步       await this.getTimeZone() // 2 获取时区timezones,方法内同步       await this.getUserInfo() // 3 获取用户信息     } Vue两个异步方法顺序执行

需求:两个异步函数按顺序执行,首先获取第一个异步函数的返回的值,接着在第二个异步函数里面调用

方法:先在第一个异步函数里返回一个promise,接着用async和await调用它

第一个异步方法 getAllNotice() {                 let data = {                     "searchParams": [{                         "fieldName": "equipmentId",                         "operate": "eq",                         "value": "000000"                     }],                     "size": -1                 }                 return new Promise((resolve) => {                     API.getNotice(data).then(res => {                         console.log(res)                         if (res.data.code == "200") {                             this.noticeList = res.data.data.list                             console.log(this.noticeList)                             resolve();                             return                         } else {                             uni.showToast({                                 title: res.data.message,                                 duration: 1000,                                 icon: "none"                             })                         }                     })                 })                             }, 第二个异步方法 //获得当前的公告列表             getNowNotice(){                 //获取当前时间戳                 var timestamp = (new Date()).getTime();                 var _this = this                 console.log(timestamp);                 //将noticeList的结束时间转换成时间戳                 for(var i=0; i<this.noticeList.length; i++){                     var endTimeStamp = TIME.TimeToTimeStamp(this.noticeList[i].endTime)                     console.log(endTimeStamp)                     if(endTimeStamp>timestamp){                         _this.noticeNewList.push(this.noticeList[i])                     }                 }                 console.log("noticeNewList",_this.noticeNewList)             }

用async和await

async onLoad(option) {             await this.getAllNotice()             await this.getNowNotice()         },

以上为个人经验,希望能给大家一个参考,也希望大家多多支持易知道(ezd.cc)。

推荐阅读

    联想垫a2207如何调用a2207平板评价

    联想垫a2207如何调用a2207平板评价,,联想a2207垫在1600 3G双网双待平板电脑的位置。作为以前的热门产品a2107升级版,a2207处理器取得了可观

    vue项目一些常见问题

    vue项目一些常见问题,组件,样式,**样式污染问题**同样的样式不需要在每个组件都复制组件内单独的样式加外层class包裹。加scope。否则只是

    01-Vue项目实战-网易云音乐-准备工作

    01-Vue项目实战-网易云音乐-准备工作,网易,项目,前言在接下来的一段时间,我会仿照网易云音乐,利用Vue开发一个移动端的网易云音乐项目。在做

    01- 第一天 spring boot2.3.1 +vue3.0 后台管理系统的研发

    01- 第一天 spring boot2.3.1 +vue3.0 后台管理系统的研发,自己的,后台,后台框架一直想开发一套完全属于自己的后台,但是18年的时候,曾经答

    Vue项目中 App.vue文件

    Vue项目中 App.vue文件,文件,内容, 在App.vue文件中,定义了一个id为app的div,在这个div板块中放置Helloworld组件,文件内容如下图所示:在

    电脑cpu调用|电脑中cpu

    电脑cpu调用|电脑中cpu,,1. 电脑中cpuCPU的中文全称是中央处理器(英文全称是Central Processing Unit),是一块超大规模的集成电路,是一台计