今天小编给大家分享一下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 获取用户信息
}
需求:两个异步函数按顺序执行,首先获取第一个异步函数的返回的值,接着在第二个异步函数里面调用
方法:先在第一个异步函数里返回一个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()
},
以上就是“Vue中的同步和异步调用顺序是什么”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。