91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue中的同步和異步調用順序是什么

發布時間:2022-01-24 15:39:15 來源:億速云 閱讀:359 作者:zzz 欄目:開發技術

今天小編給大家分享一下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()
        },

以上就是“Vue中的同步和異步調用順序是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家閱讀完這篇文章都有很大的收獲,小編每天都會為大家更新不同的知識,如果還想學習更多的知識,請關注億速云行業資訊頻道。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

莆田市| 隆林| 岑巩县| 双城市| 仪征市| 泌阳县| 灵寿县| 华阴市| 双城市| 宿松县| 进贤县| 大连市| 西峡县| 大城县| 车险| 育儿| 义乌市| 正安县| 鹿邑县| 濮阳县| 遂平县| 忻州市| 康乐县| 蒲江县| 嘉峪关市| 丽江市| 定远县| 河东区| 柳河县| 阿拉善左旗| 确山县| 澳门| 兴山县| 中牟县| 宝丰县| 日照市| 正蓝旗| 屯门区| 元谋县| 长兴县| 定西市|