如下:
分别为:是什么、有哪些、执行顺序。
跟vue、react框架一样,微信小程序框架也存在生命周期,实质也是一堆会在特定时期执行的函数
小程序中,生命周期主要分成了三部分:
·应用的生命周期
·页面的生命周期
·组件的生命周期
小程序的生命周期函数是在app.js里面调用的,通过App(Object)函数用来注册一个小程序,指定其小程序的生命周期回调。
页面生命周期函数就是当你每进入/切换到一个新的页面的时候,就会调用的生命周期函数,同样通过App(Object)函数用来注册一个页面。
组件的生命周期,指的是组件自身的一些函数,这些函数在特殊的时间点或遇到一些特殊的框架事件时被自动触发,通过Component(Object)进行注册组件。
·生命周期
(说明)
·onLaunch
小程序初始化完成时触发,全局只触发一次。
·onShow
小程序启动,或从后台进入前台显示时触发。
·onHide
小程序从前台进入后台时触发。
·onError
小程序发生脚本错误或 API 调用报错时触发。
·onPageNotFound
小程序要打开的页面不存在时触发。
·onUnhandledRejection()
小程序有未处理的 Promise 拒绝时触发。
·onThemeChange
系统切换主题时触发。
·生命周期
(说明)
作用:
·onLoad
生命周期回调—监听页面加载
发送请求获取数据
·onShow
生命周期回调—监听页面显示
请求数据
·onReady
生命周期回调—监听页面初次渲染完成
获取页面元素(少用)
·onHide
生命周期回调—监听页面隐藏
终止任务,如定时器或者播放音乐
·onUnload
生命周期回调—监听页面卸载
终止任务
·生命周期
(说明)
·created
生命周期回调—监听页面加载
·attached
生命周期回调—监听页面显示
·ready
生命周期回调—监听页面初次渲染完成
·moved
生命周期回调—监听页面隐藏
·detached
生命周期回调—监听页面卸载
·error
每当组件方法抛出错误时执行
注意的是:
组件实例刚刚被创建好时, created 生命周期被触发,此时,组件数据 this.data 就是在 Component 构造器中定义的数据 data , 此时不能调用 setData
在组件完全初始化完毕、进入页面节点树后, attached 生命周期被触发。此时, this.data 已被初始化为组件的当前值。这个生命周期很有用,绝大多数初始化工作可以在这个时机进行
在组件离开页面节点树后, detached 生命周期被触发。退出一个页面时,如果组件还在页面节点树中,则 detached 会被触发
还有一些特殊的生命周期,它们并非与组件有很强的关联,但有时组件需要获知,以便组件内部处理,这样的生命周期称为“组件所在页面的生命周期”,在 pageLifetimes 定义段中定义,如下:
·生命周期
(说明)
·show
组件所在的页面被展示时执行
·hide
组件所在的页面被隐藏时执行
代码如下:
App({ /** * 当小程序初始化完成时,会触发 onLaunch(全局只触发一次) */ onLaunch: function () { }, /** * 当小程序启动,或从后台进入前台显示,会触发 onShow */ onShow: function (options) { }, /** * 当小程序从前台进入后台,会触发 onHide */ onHide: function () { }, /** * 当小程序发生脚本错误,或者 api 调用失败时,会触发 one rror 并带上错误信息 */ one rror: function (msg) { } })
·⽤户⾸次打开⼩程序,触发 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重新开始执行。