第十九讲_HarmonyOS应用页面和自定义组件生命周期

HarmonyOS应用页面和自定义组件生命周期

  • [1. 什么叫页面](#1. 什么叫页面)
  • [2. 什么叫自定义组件](#2. 什么叫自定义组件)
  • [3. 页面的生命周期](#3. 页面的生命周期)
  • [4. 自定义组件的生命周期](#4. 自定义组件的生命周期)
  • [5. 一个页面的生命周期流程](#5. 一个页面的生命周期流程)

1. 什么叫页面

页面:即HarmonyOS应用的UI页面。

  • 由一个或者多个自定义组件组成
  • @Entry装饰的自定义组件为页面的入口组件,一个页面有且仅能有一个@Entry
  • 只有被@Entry装饰的组件才可以调用页面的生命周期

2. 什么叫自定义组件

自定义组件@Component装饰的UI单元。

  • 可以组合多个系统组件实现UI的复用
  • 可以调用组件的生命周期

3. 页面的生命周期

页面生命周期,即被@Entry装饰的组件生命周期,提供以下生命周期接口:

  • onPageShow():页面每次显示时触发一次,包括路由过程、应用进入前台等场景。
  • onPageHide():页面每次隐藏时触发一次,包括路由过程、应用进入后台等场景。
  • onBackPress():当用户点击返回按钮时触发。

4. 自定义组件的生命周期

  • aboutToAppear():组件即将出现时回调,具体时机为在创建自定义组件的新实例后,在执行其build()函数之前执行。
  • aboutToDisappear():在自定义组件析构销毁之前执行。

5. 一个页面的生命周期流程

@Entry装饰的组件(即页面)生命周期的流程图:

typescript 复制代码
/**
 * 被@Component修饰就是一个组件
 * 被@Entry修饰的组件就是一个页面
 */
@Entry
@Component
struct Index {
  @State message: string = 'Hello World'

  // 自定义组件的新实例后,在执行其build()函数之前执行
  aboutToAppear() {
    console.warn("组件被实例化了")
  }

  // 页面每次显示时触发一次,包括路由过程、应用进入前台等场景
  onPageShow() {
    console.warn("页面被显示了");
  }

  // 页面每次隐藏时触发一次,包括路由过程、应用进入后台等场景
  onPageHide() {
    console.warn("页面被隐藏了")
  }

  // 当用户点击返回按钮时触发
  onBackPress() {
    console.warn("返回")
  }

  // 自定义组件的新实例后,在执行其build()函数之前执行
  aboutToDisappear() {
    console.warn("组件被销毁了")
  }

  build() {
    Row() {
      Column() {
        Text(this.message)
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
      }
      .width('100%')
    }
    .height('100%')
  }
}
bash 复制代码
09-05 22:16:29.093 16926-23064/? W 0FEFE/JsApp: 组件被实例化了
09-05 22:16:29.094 16926-23064/? W 0FEFE/JsApp: 页面被显示了
09-05 22:16:42.125 16926-23064/com.dake.myapplication W 0FEFE/JsApp: 页面被隐藏了
09-05 22:16:50.207 16926-23064/com.dake.myapplication W 0FEFE/JsApp: 页面被显示了
09-05 22:16:53.945 16926-23064/com.dake.myapplication W 0FEFE/JsApp: 返回
09-05 22:16:53.995 16926-23064/com.dake.myapplication W 0FEFE/JsApp: 组件被销毁了
相关推荐
1024肥宅2 小时前
JavaScript 拷贝全解析:从浅拷贝到深拷贝的完整指南
前端·javascript·ecmascript 6
欧阳天风2 小时前
js实现鼠标横向滚动
开发语言·前端·javascript
盐焗西兰花2 小时前
鸿蒙学习实战之路 - 图片预览功能实现
学习·华为·harmonyos
盐焗西兰花3 小时前
鸿蒙学习实战之路:HarmonyOS 布局性能优化最佳实践
华为·性能优化·harmonyos
局i3 小时前
Vue 指令详解:v-for、v-if、v-show 与 {{}} 的妙用
前端·javascript·vue.js
꒰ঌ小武໒꒱4 小时前
RuoYi-Vue 前端环境搭建与部署完整教程
前端·javascript·vue.js·nginx
局i5 小时前
Vue 中 v-text 与 v-html 的区别:文本渲染与 HTML 解析的抉择
前端·javascript·vue.js
fruge5 小时前
接口 Mock 工具对比:Mock.js、Easy Mock、Apifox 的使用场景与配置
开发语言·javascript·ecmascript
贩卖黄昏的熊6 小时前
typescript 快速入门
开发语言·前端·javascript·typescript·ecmascript·es6
Syron7 小时前
ScaleSlider 组件实现
javascript