持续创作,加速成长!这是我参与「掘金日新计划 · 6 月更文挑战」的第17天
微信小程序
生命周期
,微信小程序跟 vue、react 框架一样,也存在生命周期,实质也是一堆会在特定时期执行的函数
- 应用的生命周期
- 页面的生命周期
- 组件的生命周期
应用的生命周期
小程序的生命周期函数是在app.js里面调用的,通过App(Object)函数用来注册一个小程序,指定其小程序的生命周期回调
| 生命周期 | 说明 |
|---|---|
| onLaunch | 小程序初始化完成时触发,全局只触发一次 |
| onShow | 小程序启动,或从后台进入前台显示时触发 |
| onHide | 小程序从前台进入后台时触发 |
| onError | 小程序发生脚本错误或 API 调用报错时触发 |
| onPageNotFound | 小程序要打开的页面不存在时触发 |
| onUnhandledRejection() | 小程序有未处理的 Promise 拒绝时触发 |
| onThemeChange | 系统切换主题时触发 |
执行过程
- ⽤户⾸次打开⼩程序,触发
onLaunch(全局只触发⼀次) - ⼩程序初始化完成后,触发
onShow⽅法,监听⼩程序显示 - ⼩程序从前台进⼊后台,触发
onHide⽅法 - ⼩程序从后台进⼊前台显示,触发
onShow⽅法 - ⼩程序后台运⾏⼀定时间,或系统资源占⽤过⾼,会被销毁
页面的生命周期
页面生命周期函数就是当你每进入/切换到一个新的页面的时候,就会调用的生命周期函数,同样通过App(Object)函数用来注册一个页面
| 生命周期 | 说明 | 作用 |
|---|---|---|
| onLoad | 生命周期回调—监听页面加载 | 发送请求获取数据 |
| onShow | 生命周期回调—监听页面显示 | 请求数据 |
| onReady | 生命周期回调—监听页面初次渲染完成 | 获取页面元素(少用) |
| onHide | 生命周期回调—监听页面隐藏 | 终止任务,如定时器或者播放音乐 |
| onUnload | 生命周期回调—监听页面卸载 | 终止任务 |
执行过程
- ⼩程序注册完成后,加载⻚⾯,触发
onLoad⽅法 - ⻚⾯载⼊后触发
onShow⽅法,显示⻚⾯ - ⾸次显示⻚⾯,会触发
onReady⽅法,渲染⻚⾯元素和样式,⼀个⻚⾯只会调⽤⼀次 - 当⼩程序后台运⾏或跳转到其他⻚⾯时,触发 onHide ⽅法
- 当⼩程序有后台进⼊到前台运⾏或重新进⼊⻚⾯时,触发
onShow⽅法 - 当使⽤重定向⽅法
wx.redirectTo()或关闭当前⻚返回上⼀⻚wx.navigateBack(),触发onUnload
组件的生命周期
组件的生命周期,指的是组件自身的一些函数,这些函数在特殊的时间点或遇到一些特殊的框架事件时被自动触发,通过Component(Object)进行注册组件
| 生命周期 | 说明 |
|---|---|
| created | 生命周期回调—监听页面加载 |
| attached | 生命周期回调—监听页面显示 |
| ready | 生命周期回调—监听页面初次渲染完成 |
| moved | 生命周期回调—监听页面隐藏 |
| detached | 生命周期回调—监听页面卸载 |
注意点
- 组件实例刚刚被创建好时,
created生命周期被触发,此时,组件数据this.data就是在Component构造器中定义的数据data, 此时不能调用setData - 在组件完全初始化完毕、进入页面节点树后,
attached生命周期被触发。此时,this.data已被初始化为组件的当前值。这个生命周期很有用,绝大多数初始化工作可以在这个时机进行 - 在组件离开页面节点树后,
detached生命周期被触发。退出一个页面时,如果组件还在页面节点树中,则detached会被触发
路由跳转
跳转方式
- wx.navigateTo(Object)
wx.navigateTo()用于保留当前页面、跳转到应用内的某个页面,使用wx.navigateBack可以返回到原页面(适用于页面少的小程序)
- wx.redirectTo(Object)
wx.redirectTo()用于关闭当前页面,跳转到应用内的某个页面(当页面过多时,被保留页面会挤占微信分配给小程序的内存,或是达到微信所限制的 10 层页面栈)
- wx.switchTab(Object)
跳转到tabBar页面,并关闭其他所有非tabBar页面
- wx.navigateBack(Object)
wx.navigateBack()用于关闭当前页面,并返回上一页面或多级页面,开发者可通过getCurrentPages()获取当前的页面栈,决定需要返回几层则设置对象的delta属性即可
- wx.reLaunch(Object)
关闭所有页面,打开到应用内的某个页面,返回的时候跳到首页
随记
navigateTo保留当前页面,跳转到应用内的某个页面,使用wx.navigateBack可以返回到原页redirectTo关闭当前页面,跳转到应用内的某个页面switchTab跳转到tabBar页面,同时关闭其他非tabBar页面navigateBack返回上一页面reLanch关闭所有页面,打开到应用内的某个页面
页面栈的关系
avigateTo新页面入栈redirectTo当前页面出栈,新页面入栈navigateBack页面不断出栈,直到目标返回页,新页面入栈switchTab页面全部出栈,只留下新的Tab页面reLanch页面全部出栈,只留下新的页面
加快小程序应用速度
启动加载性能
- 控制代码包的大小
- 分包加载
- 首屏体验(预请求,利用缓存,避免白屏,及时反馈
渲染性能
- 避免不当的使用
setData - 使用自定义组件