您好,登錄后才能下訂單哦!
今天小編給大家分享一下Vue中的同步和異步調(diào)用順序是什么的相關(guān)知識點(diǎn),內(nèi)容詳細(xì),邏輯清晰,相信大部分人都還太了解這方面的知識,所以分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后有所收獲,下面我們一起來了解一下吧。
Vue中的方法調(diào)用順序是依次進(jìn)行的,方法體內(nèi)部也是依次執(zhí)行的,但是,兩個方法體的執(zhí)行順序并不能嚴(yán)格控制。
以下方法中都帶有promise函數(shù)或異步調(diào)用。
initUserData() { this.getPsCountryList() // 1 獲取國家列表stateOptions,方法內(nèi)同步 this.getTimeZone() // 2 獲取時區(qū)timezones,方法內(nèi)同步 this.getUserInfo() // 3 獲取用戶信息 }
在實(shí)際運(yùn)行中,三個方法的執(zhí)行順序是1-2-3,但是方法3始終不能獲取到stateOptions和timezones
背后的調(diào)用順序是1-2-3,但是,方法的執(zhí)行時間并沒有嚴(yán)格控制。
如果想要做到方法調(diào)用和執(zhí)行是同步的,可以使用async和await修飾符。
async initUserData() { await this.getPsCountryList() // 1 獲取國家列表stateOptions,方法內(nèi)同步 await this.getTimeZone() // 2 獲取時區(qū)timezones,方法內(nèi)同步 await this.getUserInfo() // 3 獲取用戶信息 }
需求:兩個異步函數(shù)按順序執(zhí)行,首先獲取第一個異步函數(shù)的返回的值,接著在第二個異步函數(shù)里面調(diào)用
方法:先在第一個異步函數(shù)里返回一個promise,接著用async和await調(diào)用它
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" }) } }) }) },
//獲得當(dāng)前的公告列表 getNowNotice(){ //獲取當(dāng)前時間戳 var timestamp = (new Date()).getTime(); var _this = this console.log(timestamp); //將noticeList的結(jié)束時間轉(zhuǎn)換成時間戳 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中的同步和異步調(diào)用順序是什么”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學(xué)習(xí)更多的知識,請關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。