关于微信小程序执行顺序问题

关于微信小程序执行顺序问题,第1张

// app.js

....

doLogin() {

    if (!wx.getStorageSync("userid") && !wx.getStorageSync("token")) {

        // 登录

        wx.login({

            success: res => {

                //自己的后台

                http.post({

                    url: "/xxxxxx",

                        params: {

                        code: res.code

                    },

                    success: (data) => {

                        this.globalData.userInfo = data.userInfo

                        wx.setStorageSync("userid", data.userid)

                        wx.setStorageSync("token", data.token)

                    },

                    error: (data) => {

                    }

                })

            }

        })

    }

},

....

//这个方法就是,用个定时器,

afterLogin(that, call) {

    this.loading(that)//菊花图loading组件

    if (this.globalData.userInfo) {

        call()

    } else {

        var count = 0

        var t = setInterval(() => {

        if (this.globalData.userInfo) {

            clearInterval(t)

            call()

        } else {

            if (count >= 300) { // 30s未成功则登录失败

                clearInterval(t)

                this.loading(that)//菊花图loading组件

                //提示框方法

                this.msg.showToast(that, "获取登录信息失败")

            }

            count++

        }

        }, 100)

    }

},

....

//index.js

var app = getApp()

...

onLoad: function (options) {

    app.afterLogin(this, () => {

        //这里放,你要在登录后做的事

    })

},

...

这样能解决不?也是看别人的代码,就是用计时器setInterval每隔100毫秒执行一次,看看登录信息拿到没有,拿到了,在进行后续 *** 作。

小程序的生命周期分为 应用生命周期 、 页面生命周期

App() 必须在 app.js 中调用,必须调用且 只能调用一次 ,app.js中定义了一些应用的生命周期函数

(1)onLaunch: 初始化小程序时触发,全局只触发一次

(2)onShow: 小程序初始化完成或用户从后台切换到前台显示时触发

(3)onHide: 用户从前台切换到后台隐藏时触发

(4)onError: 小程序发生脚本错误,或者 api 调用失败时,会触发 onError 并带上错误信息

后台:点击左上角关闭,或者按了设备 Home 键离开微信,并没有直接销毁,而是进入后台

前台:再次进入微信或再次打开小程序,相当于从后台进入前台。

官方介绍 https://developers.weixin.qq.com/miniprogram/dev/reference/api/App.html

js文件中定义了一些页面生命周期函数,下面简述下这些生命周期函数的方法作用

(1)onLoad:首次进入页面加载时触发,可以在 onLoad 的参数中获取打开当前页面路径中的参数。

(2)onShow:加载完成后、后台切到前台或重新进入页面时触发

(3)onReady:页面首次渲染完成时触发

(4)onHide:从前台切到后台或进入其他页面触发

(5)onUnload:页面卸载时触发

官方介绍 https://developers.weixin.qq.com/miniprogram/dev/reference/api/Page.html

通过console.log验证它们的触发顺序

以上是对生命周期粗略的认识,如有不足请指正~

参考链接 https://www.jianshu.com/p/2e48f2468d5f


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/11662440.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-17
下一篇 2023-05-17

发表评论

登录后才能评论

评论列表(0条)

保存