小程序之生命周期

跟 vue、react 一样,微信小程序框架也存在生命周期,小程序的生命周期主要分成了两部分:

  • 应用的生命周期
  • 页面的生命周期

应用的生命周期

小程序的生命周期函数是在 app.js 里面调用的,通过App(Object)函数用来注册一个小程序,指定其小程序的生命周期回调,具体如下表:

生命周期 说明
onLaunch 小程序初始化完成时触发,全局只触发一次
onShow 小程序启动,或从后台进入前台显示时触发
onHide 小程序从前台进入后台时触发
onError 小程序发生脚本错误或 API 调用报错时触发
onPageNotFound 小程序要打开的页面不存在时触发
onUnhandledRejection() 小程序有未处理的 Promise 拒绝时触发
onThemeChange 系统切换主题时触发

页面的生命周期

页面生命周期函数就是当你每进入/切换到一个新的页面的时候,就会调用的生命周期函数,同样通过App(Object)函数用来注册一个页面

生命周期 说明
onLoad 生命周期回调—监听页面加载
onShow 生命周期回调—监听页面显示
onReady 生命周期回调—监听页面初次渲染完成
onHide 生命周期回调—监听页面隐藏
onUnload 生命周期回调—监听页面卸载

执行过程

应⽤的⽣命周期执行过程:

  • ⽤户⾸次打开⼩程序,触发 onLaunch(全局只触发⼀次)

  • ⼩程序初始化完成后,触发 onShow ⽅法,监听⼩程序显示

  • ⼩程序从前台进⼊后台,触发 onHide ⽅法

  • ⼩程序从后台进⼊前台显示,触发 onShow ⽅法

  • ⼩程序后台运⾏⼀定时间,或系统资源占⽤过⾼,会被销毁

⻚⾯⽣命周期的执行过程:

  • ⼩程序注册完成后,加载⻚⾯,触发 onLoad ⽅法
  • ⻚⾯载⼊后触发 onShow ⽅法,显示⻚⾯
  • ⾸次显示⻚⾯,会触发 onReady ⽅法,渲染⻚⾯元素和样式,⼀个⻚⾯只会调⽤⼀次
  • 当⼩程序后台运⾏或跳转到其他⻚⾯时,触发 onHide ⽅法
  • 当⼩程序有后台进⼊到前台运⾏或重新进⼊⻚⾯时,触发 onShow ⽅法
  • 当使⽤重定向⽅法 wx.redirectTo() 或关闭当前⻚返回上⼀⻚ wx.navigateBack(),触发 onUnload

当存在也应用生命周期和页面周期的时候,相关的执行顺序如下:

  • 打开小程序:(App)onLaunch –> (App)onShow –> (Pages)onLoad –> (Pages)onShow –> (pages)onRead
  • 进入下一个页面:(Pages)onHide –> (Next)onLoad –> (Next)onShow –> (Next)onReady
  • 返回上一个页面:(curr)onUnload –> (pre)onShow
  • 离开小程序:(App)onHide
  • 再次进入:小程序未销毁 –> (App)onShow(执行上面的顺序),小程序被销毁,(App)onLaunch 重新开始执行.

本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 ,转载请注明出处!