欧美高清视频一区,亚洲福利视频,国产精品自产拍在线观看桃花,国产精品自产拍在线观看桃花,久久国产三级,一区二区三区日韩在线,影音先锋日本

龍巖易富通網(wǎng)絡(luò)科技有限公司

龍巖小程序開發(fā),龍巖分銷系統(tǒng)

uniapp中onLaunch和onload的先后執(zhí)行順序

2023.06.02 | 2779閱讀 | 0條評論 | 小程序

onLaunch與onload分別是APP生命周期與頁面生命周期,理論上應(yīng)該先執(zhí)行onLaunch 后執(zhí)行頁面生命周期onLoad。然而實際上并非如此,在執(zhí)行onlaunch的同時,也會執(zhí)行onLoad生命周期,而在實際開發(fā)中往往需要優(yōu)先執(zhí)行onlaunch后再執(zhí)行onLoad,因此可以使用當前方法解決。

一、main.js添加如下代碼?

代碼如下(示例)

// 讓頁面的 onLoad 在 onLaunch 之后執(zhí)行

Vue.prototype.$onLaunched = new Promise(resolve => {

    Vue.prototype.$isResolve = resolve

})


二、在 App.vue 的 onLaunch 中增加代碼 this.$isResolve();

代碼如下(示例):

//app.vue生命周期中,onlaunch執(zhí)行時,執(zhí)行this.$isResolve()

onLaunch () {

        //發(fā)送請求

    uni.request({

        success: loginRes => {       

            // 業(yè)務(wù)邏輯

            // ...

            // 當執(zhí)行完業(yè)務(wù)邏輯,需要同步onload時,調(diào)用一下

            this.$isResolve()           

        }

    })

}


三、在頁面 onLoad 中增加代碼 await this.$onLaunched;

代碼如下(示例):

//onLoad 生命周期函數(shù)前,加async/await,用此方法同步執(zhí)行順序

        async onLoad() {

               //async/await,當執(zhí)行完APP生命周期中的onlaunch,再執(zhí)行頁面中的業(yè)務(wù)邏輯

               await this.$onLaunched;

              

               //執(zhí)行頁面中的業(yè)務(wù)邏輯

               //...

        },


個人理解

1先給onLaunch方法套一個promise實例,執(zhí)行成功后再執(zhí)行全局掛載的方法,標識當前已經(jīng)執(zhí)行完畢。
2.在頁面中利用async/await 同步執(zhí)行代碼的方法,實現(xiàn)onLaunch 在 onLoad 之后執(zhí)行


版權(quán)屬于:瞭月

本文鏈接:https://www.lervor.com/archives/128/


贊 (

發(fā)表評論

揭阳市| 白朗县| 抚松县| 蒙山县| 察雅县| 咸丰县| 潜江市| 阿合奇县| 清新县| 临夏市| 响水县| 新丰县| 那坡县| 翁牛特旗| 临猗县| 社旗县| 公主岭市| 逊克县| 弋阳县| 柳河县| 天台县| 辽阳市| 剑川县| 平顺县| 麦盖提县| 昌乐县| 应城市| 苏尼特右旗| SHOW| 胶南市| 喀喇沁旗| 曲水县| 康保县| 涞源县| 金坛市| 库车县| 元江| 南丰县| 巴林左旗| 中阳县| 曲麻莱县|