说说对小程序中生命周期的理解
# 是什么
生命周期:同vue、react一样,小程序也有生命周期的概念, 即在一定的时期执行的函数
# 组成
- 应用生命周期
- 页面生命周期
- 组件生命周期
# 怎么用
# 应用生命周期
| 生命周期 | 说明 |
|---|---|
| onLaunch | 小程序初始化完成时触发,全局只触发一次 |
| onShow | 小程序启动,或从后台进入前台显示时触发 |
| onHide | 小程序从前台进入后台时触发 |
| onError | 小程序发生脚本错误或 API 调用报错时触发 |
| onPageNotFound | 小程序要打开的页面不存在时触发 |
| onUnhandledRejection() | 小程序有未处理的 Promise 拒绝时触发 |
| onThemeChange | 系统切换主题时触发 |
# 页面生命周期
| 生命周期 | 说明 | 作用 |
|---|---|---|
| onLoad | 生命周期回调—监听页面加载 | 发送请求获取数据 |
| onShow | 生命周期回调—监听页面显示 | 请求数据 |
| onReady | 生命周期回调—监听页面初次渲染完成 | 获取页面元素(少用) |
| onHide | 生命周期回调—监听页面隐藏 | 终止任务,如定时器或者播放音乐 |
| onUnload | 生命周期回调—监听页面卸载 | 终止任务 |
# 组件生命周期
| 生命周期 | 说明 |
|---|---|
| created | 生命周期回调—监听页面加载 |
| attached | 生命周期回调—监听页面显示 |
| ready | 生命周期回调—监听页面初次渲染完成 |
| moved | 生命周期回调—监听页面隐藏 |
| detached | 生命周期回调—监听页面卸载 |
| error | 每当组件方法抛出错误时执行 |
- created阶段不能调用setData
- attached阶段值已初始化,可以进行数据操作
- detached 退出页面,但还在节点树中时触发
# pageLifetimes 特殊生命周期
| 生命周期 | 说明 |
|---|---|
| show | 组件所在的页面被展示时执行 |
| hide | 组件所在的页面被隐藏时执行 |
Component({
pageLifetimes: {
show: function() {
// 页面被展示
},
hide: function() {
// 页面被隐藏
},
}
})
# 执行过程
# 应⽤的⽣命周期执行过程:
⽤户⾸次打开⼩程序,触发 onLaunch(全局只触发⼀次)
⼩程序初始化完成后,触发onShow⽅法,监听⼩程序显示
⼩程序从前台进⼊后台,触发 onHide⽅法
⼩程序从后台进⼊前台显示,触发 onShow⽅法
⼩程序后台运⾏⼀定时间,或系统资源占⽤过⾼,会被销毁
# 页面的⽣命周期执行过程:
⼩程序注册完成后,加载⻚⾯,触发onLoad⽅法
⻚⾯载⼊后触发onShow⽅法,显示⻚⾯
⾸次显示⻚⾯,会触发onReady⽅法,渲染⻚⾯元素和样式,⼀个⻚⾯只会调⽤⼀次
当⼩程序后台运⾏或跳转到其他⻚⾯时,触发onHide⽅法
当⼩程序有后台进⼊到前台运⾏或重新进⼊⻚⾯时,触发onShow⽅法
当使⽤重定向⽅法 wx.redirectTo() 或关闭当前⻚返回上⼀⻚wx.navigateBack(),触发onUnload
# 总结
# 打开小程序
(App)onLaunch -> (App)onShow -> (Pages)onLoad -> (Pages)onShow -> (Pages)onReady
# 进入下一个页面
(Pages)onHide -> (Next)onLoad -> (Next)onShow -> (Next)onReady
# 返回上一个页面
(current)onUnload -> (pre)onShow
# 离开小程序
(App)onHide
# 再次进入
- 小程序未销毁: (App)onShow -> (Pages)onLoad -> (Pages)onShow -> (Pages)onReady
- 小程序销毁(同打开小程序):(App)onLaunch -> (App)onShow -> (Pages)onLoad -> (Pages)onShow -> (Pages)onReady
# FAQ
// https://api.git123.cn/proxy/image?url=
上次更新: 2021/12/19, 18:05:42