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() },
以上为个人经验,希望能给大家一个参考,也希望大家多多支持阿兔在线工具。