微信小程序各个生命周期(应用生命周期,页面生命周期,组件生命周期)


微信小程序各个生命周期

  • 应用生命周期
  • 页面生命周期
  • 组件生命周期

1. 应用生命周期

App(Object object)

注册小程序。接受一个 Object 参数,其指定小程序的生命周期回调等。

App() 必须在 app.js 中调用,必须调用且只能调用一次。不然会出现无法预期的后果。

属性类型说明
onLaunch(Object object)function小程序初始化完成时触发,全局只触发一次。参数也可以使用 wx.getLaunchOptionsSync 获取。
onShow(Object object)function小程序启动,或从后台进入前台显示时触发。也可以使用 wx.onAppShow 绑定监听。
onHide()function小程序从前台进入后台时触发。也可以使用 wx.onAppHide 绑定监听。
onError(String error)function小程序发生脚本错误或 API 调用报错时触发。也可以使用 wx.onError 绑定监听。
onPageNotFound(Object object)function小程序要打开的页面不存在时触发。也可以使用 wx.onPageNotFound 绑定监听。注意事项请参考 wx.onPageNotFound
onUnhandledRejection(Object object)function小程序有未处理的 Promise 拒绝时触发。也可以使用 wx.onUnhandledRejection 绑定监听。注意事项请参考 wx.onUnhandledRejection。
onThemeChange(Object object)function系统切换主题时触发。也可以使用 wx.onThemeChange 绑定监听。

示例代码

App({
  onLaunch (options) {
    // 
    console.log('小程序初始化')

  },
  onShow(options) {
    console.log('监听小程序启动或切前台')
  },
  onHide() {
    console.log('监听小程序切后台')
  },

  onError(msg) {
    console.log('错误监听函数')
  },
  onPageNotFound(res) {
    console.log('小程序要打开的页面不存在时触发');
    wx.redirectTo({ // 重定向
      url: 'pages/...'
    }) // 如果是 tabbar 页面,请使用 wx.switchTab
  }
  
})

2. 页面生命周期

Page(Object object)

注册小程序中的一个页面。接受一个 Object 类型参数,其指定页面的初始数据、生命周期回调、事件处理函数等。

属性类型说明
dataObject页面第一次渲染使用的初始数据页面加载时,data 将会以JSON字符串的形式由逻辑层传至渲染层,因此data中的数据必须是可以转成JSON的类型:字符串,数字,布尔值,对象,数组。
optionsObject渲染层可以通过 WXML 对数据进行绑定。页面的组件选项,同 Component 构造器 中的 options ,需要基础库版本 2.10.1
behaviorsString Array类似于 mixins 和traits的组件间代码复用机制,参见 behaviors,需要基础库版本 2.9.2
onLoadfunction页面加载时触发。一个页面只会调用一次,可以在 onLoad 的参数中获取打开当前页面路径中的参数。
onShowfunction页面显示/切入前台时触发。
onReadyfunction页面初次渲染完成时触发。一个页面只会调用一次,代表页面已经准备妥当,可以和视图层进行交互。
onHidefunction页面隐藏/切入后台时触发。 如 wx.navigateTo 或底部 tab 切换到其他页面,小程序切入后台等。
onUnloadfunction页面卸载时触发。如wx.redirectTo或wx.navigateBack到其他页面时。
onPullDownRefreshfunction监听用户下拉动作
onReachBottomfunction页面上拉触底事件的处理函数
onShareAppMessagefunction用户点击右上角转发
onShareTimelinefunction用户点击右上角转发到朋友圈
onAddToFavoritesfunction用户点击右上角收藏
onPageScrollfunction页面滚动触发事件的处理函数
onResizefunction页面尺寸改变时触发,详见 响应显示区域变化
onTabItemTapfunction当前是 tab 页时,点击 tab 时触发
onSaveExitStatefunction页面销毁前保留状态回调

示例代码

Page({
  /**
   * 页面的初始数据
   */
  data: {},
 /*页面生命周期*/
 onReady: function () {
    console.log('监听页面初次渲染完成')
  },
  onShow: function () {
    console.log('监听页面显示')
  },
  onHide: function () {
    console.log('监听页面隐藏')
  },
  onUnload: function () {
    console.log('监听页面卸载')
  },
  /**
   * 页面相关事件处理函数--监听用户下拉动作
   */
  onPullDownRefresh: function () {},
  /**
   * 页面上拉触底事件的处理函数
   */
  onReachBottom: function () {},
  /**
   * 用户点击右上角分享
   */
  onShareAppMessage: function () {}
})

3. 组件生命周期

组件的生命周期,指的是组件自身的一些函数,这些函数在特殊的时间点或遇到一些特殊的框架事件时被自动触发。

其中,最重要的生命周期是 created attached detached ,包含一个组件实例生命流程的最主要时间点。

  • created:组件实例刚刚被创建好时, created 生命周期被触发。此时,组件数据 this.data 就是在 Component 构造器中定义的数据 data 。 此时还不能调用 setData 。 通常情况下,这个生命周期只应该用于给组件 this 添加一些自定义属性字段。
  • attached: 在组件完全初始化完毕、进入页面节点树后, attached 生命周期被触发。此时, this.data 已被初始化为组件的当前值。这个生命周期很有用,绝大多数初始化工作可以在这个时机进行。
  • detached:在组件离开页面节点树后, detached 生命周期被触发。退出一个页面时,如果组件还在页面节点树中,则 detached 会被触发。

生命周期方法可以直接定义在 Component 构造器的第一级参数中。

自小程序基础库版本 2.2.3 起,组件的的生命周期也可以在 lifetimes 字段内进行声明(这是推荐的方式,其优先级最高)

生命周期参数描述
created在组件实例刚刚被创建时执行
attached在组件实例进入页面节点树时执行
ready在组件在视图层布局完成后执行
moved在组件实例被移动到节点树另一个位置时执行
detached在组件实例被从页面节点树移除时执行
errorObject Error每当组件方法抛出错误时执行

示例代码


lifetimes: {
  created() {
    console.log("在组件实例刚刚被创建时执行")
  },
  attached() { 
    console.log("在组件实例进入页面节点树时执行")
  },
  ready() {
    console.log("在组件在视图层布局完成后执行")
  },
  moved() {
    console.log("在组件实例被移动到节点树另一个位置时执行")
  },
  detached() {
    console.log("在组件实例被从页面节点树移除时执行")
  },
  error() {
    console.log("每当组件方法抛出错误时执行")
  },
},

组件所在页面的生命周期

还有一些特殊的生命周期,它们并非与组件有很强的关联,但有时组件需要获知,以便组件内部处理。这样的生命周期称为“组件所在页面的生命周期”,在 pageLifetimes 定义段中定义。其中可用的生命周期包括:

生命周期参数描述
show组件所在的页面被展示时执行
hide组件所在的页面被隐藏时执行
resizeObject Size组件所在的页面尺寸变化时执行

示例代码


Component({
  pageLifetimes: {
    show: function() {
      // 页面被展示
    },
    hide: function() {
      // 页面被隐藏
    },
    resize: function(size) {
      // 页面尺寸变化
    }
  }
})



文章作者: me
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 me !