目录
1、应用的生命周期
2、页面的生命周期
3、组件的生命周期
4、执行顺序
小程序中,生命周期主要分成了三部分:
① 应用的生命周期 ② 页面的生命周期 ③ 组件的生命周期
1、应用的生命周期
在 app.js 里面调用,通过 App(Object) 函数用来注册一个小程序,指定其小程序的生命周期回调。
执行过程:
⽤户⾸次打开⼩程序,触发 onLaunch(全局只触发⼀次)
⼩程序初始化完成后,触发onShow⽅法,监听⼩程序显示
⼩程序从前台进⼊后台,触发 onHide⽅法
⼩程序从后台进⼊前台显示,触发 onShow⽅法
⼩程序后台运⾏⼀定时间,或系统资源占⽤过⾼,会被销毁
2、页面的生命周期
当进入/切换到一个新的页面时调用,通过 App(Object) 函数用来注册一个页面。
执行过程:
- ⼩程序注册完成后,加载⻚⾯,触发onLoad⽅法
- ⻚⾯载⼊后触发onShow⽅法,显示⻚⾯
- ⾸次显示⻚⾯,会触发onReady⽅法,渲染⻚⾯元素和样式,⼀个⻚⾯只会调⽤⼀次
- 当⼩程序后台运⾏或跳转到其他⻚⾯时,触发onHide⽅法
- 当⼩程序有后台进⼊到前台运⾏或重新进⼊⻚⾯时,触发onShow⽅法
- 当使⽤重定向⽅法 wx.redirectTo() 或关闭当前⻚返回上⼀⻚wx.navigateBack(),触发onUnload
3、组件的生命周期
通过 Component(Object) 函数用来注册一个组件
注意的是:
- 组件实例刚刚被创建好时, created 生命周期被触发。此时,组件数据 this.data 就是在 Component 构造器中定义的数据 data , 此时不能调用 setData。
- 在组件完全初始化完毕、进入页面节点树后, attached 生命周期被触发。此时, this.data 已被初始化为组件的当前值。这个生命周期很有用,绝大多数初始化工作可以在这个时机进行。
- 在组件离开页面节点树后, detached 生命周期被触发。退出一个页面时,如果组件还在页面节点树中,则 detached 会被触发。
还有一些特殊的生命周期,它们并非与组件有很强的关联。但有时组件需要获知,以便组件内部处理,这样的生命周期称为“组件所在页面的生命周期”,在
pageLifetimes
定义段中定义,如下:Component({ pageLifetimes: { show: function() { // 页面被展示 }, hide: function() { // 页面被隐藏 } } })
4、执行顺序
当存在也应用生命周期和页面周期的时候,相关的执行顺序如下:
打开小程序:(App)onLaunch --> (App)onShow --> (Pages)onLoad --> (Pages)onShow --> (pages)onReady
进入下一个页面:(Pages)onHide --> (Next)onLoad --> (Next)onShow --> (Next)onReady
返回上一个页面:(curr)onUnload --> (pre)onShow
离开小程序:(App)onHide
再次进入:小程序未销毁 --> (App)onShow(执行上面的顺序),小程序被销毁,(App)onLaunch重新开始执行