网页前端后台技巧(CSS+HTML)前端笔记

小程序生命周期

2021-02-19  本文已影响0人  流眸Tel

1. 生命周期

1.1 什么是生命周期?

生命周期就是指一个对象的生老病死。
基本涵义可以通俗地理解为“从摇篮到坟墓”(Cradle-to-Grave)的整个过程。

小程序生命周期.png

1.2 用途

在技术中心,我们可以理解生命周期为从一个应用从创建到销毁的过程。在项目层面,我们每一个完整的项目中都会在不同时间不同位置处理不同问题及不同需求,也就是在特点时间执特定函数

2. 小程序的生命周期

根据官网介绍,小程序生命周期包含7个阶段:

阶段 类型 最低版本 说明
onLaunch function / 监听小程序初始化
onShow function / 监听小程序启动或切前台
onHide function / 监听小程序切后台
onError function / 错误监听函数
onPageNotFound function 1.9.90 页面不存在监听函数
onUnhandleRejection function 2.10.0 未处理的 Promise 拒绝事件监听函数
onThemeChange function 2.11.0 监听系统主题变化

注:

接受一个 Object 参数,其指定小程序的生命周期回调等。

App() 必须在 app.js 中调用,必须调用且只能调用一次。不然会出现无法预期的后果。

2.1 onLaunch

触发时机:

小程序一启动时触发,被隐藏重新打开不触发,被销毁再打开才会触发。

作用:

代码示例:

App({
    // 小程序一启动时触发,被隐藏重新打开不触发,被销毁再打开才会触发
    onLaunch (options) {
        console.log('触发了 onLaunch');
    },
})

2.2 onShow

触发时机:

与 onHide 是一对,当应用重新被显示的时候或者第一次启动时都会触发

作用:

代码示例:

App({
    // 当应用重新被显示的时候或者第一次启动时都会触发
    onShow (options) {
        console.log('触发了 onShow');
    },
})

2.3 onHide

触发时机:

当整个小程序隐藏时会触发,如切换到其他APP

作用:

代码示例:

App({
    // 当整个小程序隐藏时会触发,如切换到其他APP
    onHide (options) {
        console.log('触发了 onHide');
    },
})

2.4 onError

触发时机:

小程序运行出错时触发

作用:

代码示例:

App({
    // 小程序运行出错时触发
    onError (options) {
        console.log('触发了 onError');
    },
})

2.5 onPageNotFound

触发时机:

页面不存在时触发

举例:

作用:

代码示例:

App({
    // 页面不存在时触发
    onPageNotFound (options) {
        wx.redirectTo({
            url: 'pages/...'
        }) // 如果是 tabbar 页面,请使用 wx.switchTab
    },
})

2.5 onPageNotFound

触发时机:

页面不存在时触发

举例:

作用:

代码示例:

App({
    // 页面不存在时触发
    onPageNotFound (options) {
        wx.redirectTo({
            url: 'pages/...'
        }) // 如果是 tabbar 页面,请使用 wx.switchTab
    },
})

2.6 onUnhandledRejection

触发时机:

promise中的reject未被捕获处理时触发

作用:

代码示例:

App({
    // onLaunch
    onLaunch() {
        new Promise((resolve,reject)=>{
            // 触发reject 
            reject({"msg":"错误提示"})
        }).catch(err=>{
            // catch了 reject 那么 onUnhandledRejection 就不会触发了
            console.log("捕获reject");
            console.log(err);
        })
    },

    // promise中的reject未被捕获处理时触发
    onUnhandledRejection(err){
        console.log("onUnhandledRejection 当发现未被捕获的reject时触发");
        console.log(err);
    }
})

2.7 onThemeChange

触发时机:

手机系统的主题模式(如黑夜模式)切换时触发

作用:

代码示例:

App({
    // promise中的reject未被捕获处理时触发
    onThemeChange(theme){
        console.log(theme); // 'dark' | 'light'
    }
})
上一篇下一篇

猜你喜欢

热点阅读