Vue中的同步和异步调⽤顺序详解
⽬录
Vue的同步和异步调⽤顺序
例如
Vue两个异步⽅法顺序执⾏
第⼀个异步⽅法
第⼆个异步⽅法
Vue的同步和异步调⽤顺序
Vue中的⽅法调⽤顺序是依次进⾏的,⽅法体内部也是依次执⾏的,但是,两个⽅法体的执⾏顺序并不能严格控制。以下⽅法中都带有promise函数或异步调⽤。
initUserData() {
}
在实际运⾏中,三个⽅法的执⾏顺序是1-2-3,但是⽅法3始终不能获取到stateOptions和timezones
背后的调⽤顺序是1-2-3,但是,⽅法的执⾏时间并没有严格控制。
如果想要做到⽅法调⽤和执⾏是同步的,可以使⽤async和await修饰符。
例如
async initUserData() {
PsCountryList() // 1 获取国家列表stateOptions,⽅法内同步
TimeZone() // 2 获取时区timezones,⽅法内同步
UserInfo() // 3 获取⽤户信息
}
Vue两个异步⽅法顺序执⾏
需求:两个异步函数按顺序执⾏,⾸先获取第⼀个异步函数的返回的值,接着在第⼆个异步函数⾥⾯调⽤
⽅法:先在第⼀个异步函数⾥返回⼀个promise,接着⽤async和await调⽤它
第⼀个异步⽅法
getAllNotice() {
let data = {
"searchParams": [{
"fieldName": "equipmentId",
"operate": "eq",
"value": "000000"
}],
"size": -1
}
return new Promise((resolve) => {
console.log(res)
if (de == "200") {
console.iceList)
resolve();
return
} else {
uni.showToast({
await和async使用方法title: ssage,
duration: 1000,
icon: "none"
})
}
})
})
},
第⼆个异步⽅法
/
/获得当前的公告列表
getNowNotice(){
//获取当前时间戳
var timestamp = (new Date()).getTime();
var _this = this
console.log(timestamp);
//将noticeList的结束时间转换成时间戳
for(var i=0; i&iceList.length; i++){
var endTimeStamp = TIME.iceList[i].endTime) console.log(endTimeStamp)
if(endTimeStamp>timestamp){
_iceNewList.iceList[i])
}
}
console.log("noticeNewList",_iceNewList)
}
⽤async和await
async onLoad(option) {
AllNotice()
NowNotice()
},
以上为个⼈经验,希望能给⼤家⼀个参考,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论