我的网站开发技术经验总结 我的网站开发技术经验总结
首页

fangdown

我的网站开发技术经验总结
首页
  • 大前端

    • nodejs

    • git

    • CI

    • 小程序

      • 说说对小程序的理解
      • 说说对小程序中生命周期的理解
        • 是什么
          • 组成
        • 怎么用
          • 应用生命周期
          • 页面生命周期
          • 组件生命周期
        • 执行过程
          • 应⽤的⽣命周期执行过程:
          • 页面的⽣命周期执行过程:
        • 总结
          • 打开小程序
          • 进入下一个页面
          • 返回上一个页面
          • 离开小程序
          • 再次进入
        • FAQ
      • 说说如何提高小程序的性能
      • 说说微信小程序的登录流程
      • 说说小程序页面跳转有哪些方式
    • docker

    • Typescript

    • webpack

    • 安全

  • 基础

  • 框架

  • 情商

  • 算法

  • 网络

  • 千锤百炼
  • 大前端
  • 小程序
fangdown
2021-10-26
目录

说说对小程序中生命周期的理解

# 是什么

生命周期:同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
说说对小程序的理解
说说如何提高小程序的性能

← 说说对小程序的理解 说说如何提高小程序的性能→

最近更新
01
多分支修复撞车的问题
05-01
02
如何成为架构师
01-23
03
服务器部署全过程
11-23
更多文章>
Theme by Vdoing | Copyright © 2019-2026 fangdown | 粤ICP备19079809号
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式