HarmonyOS NEXT开发进阶(九):UIAbility 组件生命周期及启动模式讲解

news/2025/1/21 20:07:45/

文章目录

    • 一、前言
    • 二、UIAbility 组件生命周期
    • 三、UIAbility 组件启动模式
      • 3.1 singleton 单实例启动模式
      • 3.2 standard 标准实例启动模式
      • 3.3 specified 指定实例启动模式
    • 四、拓展阅读

一、前言

UIAbility组件是一种包含UI界面的应用组件,主要用于和用户交互。

UIAbility组件是系统调度的基本单元,为应用提供绘制界面的窗口;一个UIAbility组件中可以通过多个页面来实现一个功能模块。每一个UIAbility组件实例,都对应于一个最近任务列表中的任务。

UIAbility组件就像手机上的一个应用,它负责展示应用的用户界面,用户可以通过它来和应用进行互动。每个UIAbility组件可以包含多个不同的界面,就像应用中的不同页面。用户每次在手机上打开一个应用,实际上是启动了一个UIAbility组件的实例,这个应用会在最近任务列表中显示。这个机制让用户能够轻松切换和管理不同应用和它们的界面。

为使应用能够正常使用UIAbility,需要在module.json5配置文件的abilities标签中声明UIAbility的名称、入口、标签等相关信息。

在这里插入图片描述

以下为设置的UIAbility参数:

{"module": {// ..."abilities": [{"name": "EntryAbility", // UIAbility组件的名称"srcEntrance": "./ets/entryability/EntryAbility.ts", // UIAbility组件的代码路径"description": "$string:EntryAbility_desc", // UIAbility组件的描述信息"icon": "$media:icon", // UIAbility组件的图标"label": "$string:EntryAbility_label", // UIAbility组件的标签"startWindowIcon": "$media:icon", // UIAbility组件启动页面图标资源文件的索引"startWindowBackground": "$color:start_window_background", // UIAbility组件启动页面背景颜色资源文件的索引// ...}]}
}

二、UIAbility 组件生命周期

UIAbility就像是应用中的一个窗口或界面,拥有自己的生命周期,就像一个角色有不同的状态。这个生命周期包括创建/销毁/前台/后台四个状态:

  • Create(创建):当用户打开应用或者切换到应用时,UIAbility被创建。例如用户打开一个应用,应用的界面被呈现在屏幕上。

  • Foreground(前台):当应用界面处于活跃状态时,它处于前台状态。例如用户正在使用一个应用,它是当前的焦点。

  • Background(后台):如果你切换到了其他应用,原来的应用就进入了后台状态。UIAbility也会相应地从前台变成后台状态。

  • Destroy(销毁):当用户关闭应用或者应用被系统销毁时,UIAbility也会被销毁。例如用户关闭一个应用,它的界面消失了。

这些状态变化可以帮助应用了解UIAbility在不同时刻的状态,从而执行不同的操作或者保持应用的一致性。

四种声明周期间的转换方式可以用以下流程图表示。

在这里插入图片描述

实际项目中,在EntryAbility.ts文件内容定义如下:

import { AbilityConstant, UIAbility, Want } from '@kit.AbilityKit';
import { hilog } from '@kit.PerformanceAnalysisKit';
import { window } from '@kit.ArkUI';export default class EntryAbility extends UIAbility {onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate');}onDestroy(): void {hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onDestroy');}onWindowStageCreate(windowStage: window.WindowStage): void {// Main window is created, set main page for this abilityhilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageCreate');windowStage.loadContent('pages/Index', (err) => {if (err.code) {hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? '');return;}hilog.info(0x0000, 'testTag', 'Succeeded in loading the content.');});}onWindowStageDestroy(): void {// Main window is destroyed, release UI related resourceshilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageDestroy');}onForeground(): void {// Ability has brought to foregroundhilog.info(0x0000, 'testTag', '%{public}s', 'Ability onForeground');}onBackground(): void {// Ability has back to backgroundhilog.info(0x0000, 'testTag', '%{public}s', 'Ability onBackground');}
}

其中,Create状态为在应用加载过程中,UIAbility实例创建完成时触发,系统会调用onCreate()回调。可以在该回调中进行应用初始化操作,例如变量定义资源加载等,用于后续的UI界面展示。

每个UIAbility类实例都会与一个WindowStage类实例绑定,WindowStage类起到了应用进程内窗口管理器的作用,它包含一个主窗口。也就是说,UIAbility通过WindowStage持有了一个窗口,该窗口为ArkUI提供了绘制区域。

可以理解为当应用程序启动时,系统会自动为每个UIAbility实例创建一个WindowStage(窗口舞台)。这个WindowStage就像是应用界面的舞台,上面可以加应用需要的各种UI元素。

根据鸿蒙开发应用的stage开发模型工作原理,UIAbility组件生命周期回调函数及WindowStage回调函数间的流转方式如下图所示:
在这里插入图片描述

WindowStage创建完成后,系统会调用onWindowStageCreate()回调函数。在这个函数里,开发者可以设置所需的UI界面,比如加载各种页面,设置UI元素的样式等。还可以订阅WindowStage事件,比如获得焦点(用户正在与应用交互)或失去焦点(应用不再是用户的焦点)、可见或不可见等。这些事件让应用能够响应用户的操作。

onWindowStageCreate()回调函数中,通常会使用loadContent()方法来加载应用要显示的页面。同时,也可以根据需要订阅各种WindowStage事件,以便在用户操作发生时做出相应的响应。

当用户退出应用或者应用被系统销毁时,对应的UIAbility实例会被销毁。在这之前,系统会先调用onWindowStageDestroy()回调函数。在这个函数里,可以释放UI界面所占用的资源,做一些清理工作。比如,可以在这里注销之前订阅的获得焦点或失去焦点等WindowStage事件,以确保资源被正确释放,应用退出时不会出现问题。

这样,通过在WindowStage的创建和销毁过程中设置相应的回调函数,使得应用就能够在不同的阶段执行不同的操作,从而保证用户体验的一致性和应用的稳定性。

ForegroundBackground状态分别在UIAbility实例切换至前台和切换至后台时触发,对应于onForeground()回调和onBackground()回调。

onForeground()回调,在UIAbility的UI界面可见之前,如UIAbility切换至前台时触发。可以在onForeground()回调中申请系统需要的资源,或者重新申请在onBackground()中释放的资源。

onBackground()回调,在UIAbility的UI界面完全不可见之后,如UIAbility切换至后台时候触发。可以在onBackground()回调中释放UI界面不可见时无用的资源,或者在此回调中执行较为耗时的操作,例如状态保存等。

例如应用在使用过程中需要使用用户定位时,假设应用已获得用户的定位权限授权。在UI界面显示之前,可以在onForeground()回调中开启定位功能,从而获取到当前的位置信息。

当应用切换到后台状态,可以在onBackground()回调中停止定位功能,以节省系统的资源消耗。

注意⚠️:预览模式是查看不了onForeground()onBackground()这两个回调函数执行的。

Destroy状态在UIAbility实例销毁时触发。可以在onDestroy()回调中进行系统资源的释放、数据的保存等操作。

例如调用terminateSelf()方法停止当前UIAbility实例,从而完成UIAbility实例的销毁;或者用户使用最近任务列表关闭该UIAbility实例,完成UIAbility的销毁。

三、UIAbility 组件启动模式

UIAbility的启动模式是指UIAbility实例在启动时的不同呈现状态。针对不同的业务场景,系统提供了三种启动模式:

  • singleton(单实例模式)
  • standard(标准实例模式)
  • specified(指定实例模式)

通过在module.json5配置文件中的"launchType"字段配置为singletonstandardspecified即可。

{"module": {// ..."abilities": [{"launchType": "multiton", // 支持配置为singleton、standard、specified三种启动模式// ...}]}
}

3.1 singleton 单实例启动模式

Singleton启动模式是一种应用程序的启动方式,通常是默认的启动方式。在这个模式下,当使用startAbility()方法来启动一个UIAbility时,如果已经存在相同类型的UIAbility实例,系统会复用现有的实例,而不会创建新的,此时只会进入该UIAbilityonNewWant()回调,不会进入其onCreate()onWindowStageCreate()生命周期回调。这意味着在最近任务列表中,只会存在一个该类型的UIAbility实例。

就好像有一个应用,当多次打开同一功能页面时,不会每次打开都创建新的页面,而是会重新使用已经存在的页面。这样可以节省系统资源,提高应用的运行效率,而且在最近任务列表中只会看到一个相同类型的页面。这个模式通常用于确保应用不会出现大量相同的界面实例,以提供更好的用户体验和系统性能。

3.2 standard 标准实例启动模式

standard启动模式为标准实例模式,每次调用startAbility()方法时,都会在应用进程中创建一个新的该类型UIAbility实例。即在最近任务列表中可以看到有多个该类型的UIAbility实例。

3.3 specified 指定实例启动模式

Specified启动模式是一种特殊的启动模式,通常用于特定场景,比如文档编辑应用。它允许开发者在创建UIAbility实例之前为该实例指定一个唯一的标识字符串(称为Key)。当UIAbility实例与这个Key绑定之后,在后续调用startAbility()方法时,系统会询问应用要打开哪个与特定Key绑定的UIAbility实例。

这种方式可以理解为每个UIAbility实例都有一个特定的身份标识(Key)。每次开发者启动UIAbility时,系统会根据这个Key来判断是复用已存在的特定Key绑定的UIAbility实例,还是创建一个新的实例。例如,在文档编辑应用中,如果想新建一个文档,可以使用一个新的Key,这将创建一个新的UIAbility实例;但如果想打开一个已保存的文档,可以使用该文档对应的Key,这将打开与之绑定的已存在的UIAbility实例。

所以,这种模式允许应用在运行时根据特定的Key来决定是否创建新实例或复用已有实例,以便满足不同的业务需求,比如确保每个文档有自己独立的编辑界面或者确保打开相同文档时共享同一个界面。

UIAbility配置为指定实例模式,再次调用startAbility()方法启动该UIAbility实例,且AbilityStageonAcceptWant()回调匹配到一个已创建的UIAbility实例。此时,再次启动该UIAbility时,只会进入该UIAbilityonNewWant()回调,不会进入其onCreate()onWindowStageCreate()生命周期回调。

四、拓展阅读

  • 《UIAbility组件官网介绍》
  • 《HarmonyOS NEXT开发进阶(八):Stage模型开发概述》

http://www.ppmy.cn/news/1565028.html

相关文章

React 中hooks之useReducer使用场景和方法总结

1. useReducer 基本概念 useReducer 是 React 的一个 Hook,用于管理复杂的状态逻辑。它接收一个 reducer 函数和初始状态,返回当前状态和 dispatch 函数。 1.1 基本语法 const [state, dispatch] useReducer(reducer, initialState, init);reducer: …

基于Python的多元医疗知识图谱构建与应用研究(下)

五、基于医疗知识图谱的医疗知识图谱程序构建 5.1 数据层构建 5.1.1 数据源选择与获取 在构建基于医疗知识图谱的医疗知识图谱数据层时,数据源的选择与获取至关重要。数据源的质量和丰富度直接决定了知识图谱的可靠性和实用性。医学文献是重要的数据源之一,包括学术期刊论…

AGI之Agent:《Agent AI: Surveying the Horizons of Multimodal Interaction智能体AI:多模态交互视野的考察》翻译与解读

AGI之Agent:《Agent AI: Surveying the Horizons of Multimodal Interaction智能体AI:多模态交互视野的考察》翻译与解读 导读:这篇文章探讨了一种新的多模态智能代理体系结构,该体系结构可感知视觉刺激、语言输入和其他环境相关数据&#xf…

Solidity01 Solidity极简入门

一、Solidity 简介 Solidity 是一种用于编写以太坊虚拟机(EVM)智能合约的编程语言。我认为掌握 Solidity 是参与链上项目的必备技能:区块链项目大部分是开源的,如果你能读懂代码,就可以规避很多亏钱项目。 Solidity …

从CRUD到高级功能:EF Core在.NET Core中全面应用(三)

目录 IQueryable使用 原生SQL使用 实体状态跟踪 全局查询筛选器 并发控制使用 IQueryable使用 在EFCore中IQueryable是一个接口用于表示可查询的集合,它继承自IEnumerable但具有一些关键的区别,使得它在处理数据库查询时非常有用,普通集…

Android 空包签名(详细版)

之前是不是没听说过,脑瓜子嗡嗡的吧。为了更加的生动形象,我这里用我之前写的demo来做这个演示。 就决定是你了,TranslateDemo,这是一个百度翻译Demo,看过这篇博客应该记忆犹新,下面先获取keystore文件。 …

拟合算法 (matlab工具箱)

拟合算法: 1线性最小二乘法拟合 使用matlab进行求解 拟合优度:R^2 拟合优度的matlab代码: 2,Matlab工具箱的教学 一些函数: 拟合算法: 插值算法中,得到的多项式f(x)要经过所有样本点。但是如果样本点太多&#…

Windows上同时配置GitHub和Gitee服务

Windows上同时配置GitHub和Gitee服务 摘要摘要 初始化添加用户名和邮箱 创建密钥ssh keys配置文件配置GitHub Gitee公钥GithubGitee 参考文章 摘要 摘要 本文详细介绍了在Windows系统上同时配置GitHub和Gitee服务的步骤。首先,通过命令行工具初始化Git配置&#x…