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

相关推荐
全球通史22 分钟前
HarmonyOS机械臂蓝牙控制应用开发完整教程
华为·harmonyos
爱吃大芒果29 分钟前
Flutter 表单开发实战:表单验证、输入格式化与提交处理
开发语言·javascript·flutter·华为·harmonyos
狮子也疯狂32 分钟前
跨平台适配:Flutter在鸿蒙生态中的应用
flutter·华为·harmonyos
不爱吃糖的程序媛1 小时前
Flutter-OH OAuth 鸿蒙平台适配详细技术文档
javascript·flutter·harmonyos
讯方洋哥1 小时前
判断、循环
harmonyos
未来之窗软件服务2 小时前
幽冥大陆(五十四)V10酒店门锁SDK 鸿蒙(HarmonyOS)——东方仙盟筑基期
华为·harmonyos·仙盟创梦ide·东方仙盟·东方仙盟sdk
柒儿吖2 小时前
命令行esh在开源鸿蒙PC平台的工程实践
开源·harmonyos·命令行
Lois_Luo2 小时前
基于鸿蒙(HarmonyOS)系统的 GPS 数据采集 APP 设计与实现方案
华为·harmonyos·gps采集
子榆.2 小时前
Flutter 与开源鸿蒙(OpenHarmony)离线能力与数据同步架构设计:打造高可用跨端应用
flutter·开源·harmonyos
不爱吃糖的程序媛3 小时前
开源鸿蒙跨平台赋能:Flutter/RN/KMP/CMP 多栈适配
flutter·开源·harmonyos