HarmonyOS的页面生命周期 和 组件生命周期

总结的如有问题,欢迎大家指正!

以下是基于鸿蒙(HarmonyOS)开发的 页面生命周期组件生命周期 的总结。


一、UIAbility 生命周期

UIAbility 是应用的基本交互单元,其生命周期由系统管理,分为以下核心阶段:

  1. onCreate()
    • UIAbility 实例创建时触发,用于初始化非界面相关资源(如数据读取、变量定义)。
  2. onWindowStageCreate(windowStage)
    • 窗口阶段创建时触发,需在此加载页面内容(如 windowStage.loadContent('pages/Index'))并订阅窗口事件(如获焦/失焦)。
  3. onForeground()
    • UIAbility 切换至前台时触发(如应用从后台恢复),用于重新申请资源(如定位功能)。
  4. onBackground()
    • UIAbility 切换至后台时触发,释放非必要资源(如停止定位)或保存临时数据。
  5. onWindowStageDestroy()
    • 窗口阶段销毁时触发,释放 UI 资源(如注销事件监听)。
  6. onDestroy()
    • UIAbility 销毁时触发,执行最终资源清理和数据持久化。

二、页面生命周期(@Entry 组件)

页面由 @Entry 装饰的组件作为根节点,其生命周期仅对入口组件生效:

  1. onPageShow()
    • 触发场景:页面显示(首次进入、从后台返回、路由跳转后返回)。
    • 用途:恢复数据(如刷新列表)或重新申请资源。
  2. onPageHide()
    • 触发场景:页面隐藏(跳转至其他页面、应用进入后台)。
    • 用途:保存临时状态或释放页面独占资源。
  3. onBackPress()
    • 触发场景:用户点击物理/导航返回键。
    • 返回值 :返回 true 可拦截默认返回行为(如弹窗确认)。

三、组件生命周期(@Component 组件)

自定义组件的生命周期由 ArkUI 框架管理,核心方法如下:

  1. aboutToAppear()
    • 触发时机 :组件实例创建后,build() 执行前。
    • 允许操作 :初始化数据、订阅事件,可修改状态变量(如 @State)。
  2. aboutToDisappear()
    • 触发时机 :组件销毁前(如 if 条件不满足、ForEach 数组变化)。
    • 禁止操作 :修改状态变量(尤其是 @Link),避免应用行为异常。
  3. onDidBuild()
    • 触发时机build() 执行完成后。
    • 限制:不建议在此修改状态变量或触发动画,可能导致 UI 不稳定。

组件生命周期的执行顺序

  • 创建时 :父组件 aboutToAppear → 子组件 aboutToAppear → 父组件 build → 子组件 build
  • 销毁时 :子组件 aboutToDisappear → 父组件 aboutToDisappear

四、关键场景下的生命周期协同

  1. 页面跳转(router.pushUrl
    • 原页面触发 onPageHide,新页面触发 onPageShow,原页面未被销毁,组件不触发 aboutToDisappear
  2. 页面替换(router.replaceUrl
    • 原页面触发 onPageHide → 组件依次触发 aboutToDisappear → 新页面初始化。
  3. 应用后台切换
    • 仅触发页面级 onPageHide/onPageShow,不触发组件销毁。
  4. 组件条件渲染
    • if 条件从 true 变为 false,子组件触发 aboutToDisappear;条件恢复时重新创建实例,触发 aboutToAppear

五、高级生命周期(Navigation 组件)

若使用 Navigation 作为路由容器,其 NavDestination 组件扩展了以下特有生命周期:

  1. onWillAppear:组件挂载到组件树前,修改状态变量会立即生效。
  2. onShown:页面布局完成后触发,适用于获取元素尺寸。
  3. onWillDisappear:组件销毁前(含转场动画),可执行动画预处理。

六、最佳实践与注意事项

  1. 资源管理
    • aboutToDisappearonPageHide 中释放资源(如关闭定时器、取消网络请求)。
  2. 状态变量
    • 避免在 aboutToDisappear 中修改 @Link 变量,可能引发同步源异常。
  3. 异步操作
    • 不在生命周期回调中使用 async/await,防止组件因闭包引用延迟回收。

附:生命周期时序示例

  • 冷启动应用
graph LR A[MyComponent.aboutToAppear] --> B[MyComponent.build] --> C[Child.aboutToAppear] --> D[Child.build] --> E[onPageShow]
  • 跳转至新页面
graph LR A[Index.onPageHide] --> B[Page2.aboutToAppear] --> C[Page2.build] --> D[Page2.onPageShow]
  • 返回原页面
graph LR A[Page2.onBackPress] --> B[Page2.onPageHide] --> C[Index.onPageShow]

额外说明:若页面未被销毁,不触发 aboutToAppear

相关推荐
遇到困难睡大觉哈哈6 小时前
HarmonyOS 公共事件机制介绍以及多进程之间的通信实现(9000字详解)
华为·harmonyos
幽蓝计划9 小时前
HarmonyOS NEXT仓颉开发语言实战案例:外卖App
开发语言·harmonyos
伍哥的传说9 小时前
鸿蒙系统(HarmonyOS)应用开发之实现电子签名效果
开发语言·前端·华为·harmonyos·鸿蒙·鸿蒙系统
Georgewu11 小时前
【HarmonyOS】应用开发拖拽功能详解
harmonyos
塞尔维亚大汉11 小时前
鸿蒙内核源码分析(构建工具篇) | 顺瓜摸藤调试鸿蒙构建过程
源码·harmonyos
kumalab14 小时前
HarmonyOS ArkTS卡片堆叠滑动组件实战与原理详解(含源码)
华为·harmonyos
别说我什么都不会15 小时前
【OpenHarmony】鸿蒙开发之xml2jsDemo
harmonyos
HarmonyOS_SDK18 小时前
HarmonyOS免密认证方案 助力应用登录安全升级
harmonyos
zhanshuo20 小时前
鸿蒙操作系统核心特性解析:从分布式架构到高效开发的全景技术图谱
harmonyos
塞尔维亚大汉20 小时前
鸿蒙内核源码分析(编译过程篇) | 简单案例窥视编译全过程
源码·harmonyos