Stage 模型

本文详细介绍了HarmonyOS的应用和组件配置,包括Stage模型结构、工程级和模块级目录、app.json5和module.json5配置文件,以及UIAbility的生命周期管理和启动模式。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1. 基本概念

  • FA模型:HarmonyOS早期版本开始支持的模型,已经不再推荐。
  • Stage模型:HarmonyOS 3.1版本开始新增的模型,目前主推并且会长期演进的模型。

Stage模型结构:
在这里插入图片描述

2. 应用及组件配置

2.1 工程级目录

在这里插入图片描述

  • AppScope 中存放应用全局所需要的资源文件。
  • entry 是应用的主模块,存放HarmonyOS应用的代码、资源等。
  • oh_modules 是工程的依赖包,存放工程依赖的源文件。
  • build-profile.json5 是工程级配置信息,包括签名、产品配置等。
  • hvigorfile.ts 是工程级编译构建任务脚本,hvigor是基于任务管理机制实现的一款全新的自动化构建工具,主要提供任务注册编排,工程模型管理、配置管理等核心能力。
  • oh-package.json5 是工程级依赖配置文件,用于记录引入包的配置信息。

在AppScope,其中有resources文件夹和配置文件app.json5。AppScope>resources>base中包含element和media两个文件夹,

  • 其中element文件夹主要存放公共的字符串、布局文件等资源。
  • media存放全局公共的多媒体资源文件。

2.2 模块级目录

在这里插入图片描述
entry>src 目录中主要包含总的main文件夹,单元测试目录ohosTest,以及模块级的配置文件。

  • main 文件夹中,ets文件夹用于存放ets代码,resources文件存放模块内的多媒体及布局文件等,module.json5文件为模块的配置文件。
  • ohosTest 是单元测试目录。
  • build-profile.json5 是模块级配置信息,包括编译构建配置项。
  • hvigorfile.ts 文件是模块级构建脚本。
  • oh-package.json5 是模块级依赖配置信息文件。

进入src>main>ets目录中,其分为entryability、pages两个文件夹。

  • entryability存放ability文件,用于当前ability应用逻辑和生命周期管理。
  • pages存放UI界面相关代码文件,初始会生成一个Index页面。

resources目录下存放模块公共的多媒体、字符串及布局文件等资源,分别存放在element、media文件夹中。

2.3 app.json5 全局配置文件

AppScope>app.json5 是应用的全局的配置文件,用于存放应用公共的配置信息。

app.json5配置信息及描述:

属性描述
bundleName包名,使用域名倒置的格式,在创建应用的时候就已经确定了
vendor应用程序供应商
versionCode用于区分应用版本
versionName版本号
icon应用的图标
label应用名

2.4 module.json5 模块配置文件

entry>src>main>module.json5 是模块的配置文件,包含当前模块的配置信息。

其中module对应的是模块的配置信息,一个模块对应一个打包后的hap包,hap包全称是HarmonyOS Ability Package,其中包含了ability、第三方库、资源和配置文件。

module.json5默认配置属性及描述:

属性描述
name该标签标识当前module的名字,module打包成hap后,表示hap的名称,标签值采用字符串表示(最大长度31个字节),该名称在整个应用要唯一。
type表示模块的类型,类型有三种,分别是entry、feature和har。
srcEntry当前模块的入口文件路径。
description当前模块的描述信息。
mainElement该标签标识hap的入口ability名称或者extension名称。只有配置为mainElement的ability或者extension才允许在服务中心露出。
deviceTypes该标签标识hap可以运行在哪类设备上,标签值采用字符串数组的表示。
deliveryWithInstall标识当前Module是否在用户主动安装的时候安装,表示该Module对应的HAP是否跟随应用一起安装。
- true:主动安装时安装。- false:主动安装时不安装。
installationFree标识当前Module是否支持免安装特性。
- true:表示支持免安装特性,且符合免安装约束。- false:表示不支持免安装特性。
pages对应的是main_pages.json文件,用于配置ability中用到的page信息。
abilities是一个数组,存放当前模块中所有的ability元能力的配置信息,其中可以有多个ability。

对于abilities中每一个ability的属性项,其描述信息如下表:

属性描述
name该标签标识当前ability的逻辑名,该名称在整个应用要唯一,标签值采用字符串表示(最大长度127个字节)。
srcEntryability的入口代码路径。
descriptionability的描述信息。
iconability的图标。该标签标识ability图标,标签值为资源文件的索引。该标签可缺省,缺省值为空。如果ability被配置为MainElement,该标签必须配置。
labelability的标签名。
startWindowIcon启动页面的图标。
startWindowBackground启动页面的背景色。
launchType设置启动模式,可选值:singleton|standard|specified|multiton
visibleability是否可以被其他应用程序调用,true表示可以被其它应用调用, false表示不可以被其它应用调用。
skills标识能够接收的意图的action值的集合,取值通常为系统预定义的action值,也允许自定义。
entities标识能够接收的Want的Action值的集合,取值通常为系统预定义的action值,也允许自定义。
actions标识能够接收Want的Entity值的集合。

2.5 main_pages.json 页面路径配置文件

entry/src/main/resources/base/profile/main_pages.json 文件保存的是页面page的路径配置信息,所有需要进行路由跳转的page页面都要在这里进行配置。

3.UIAbility生命周期

在这里插入图片描述

4.页面及组件生命周期

在这里插入图片描述

5.UIAbility的启动模式

  • Singleton 启动模式:每一个UIAbility只存在唯一实例。是默认启动模式。任务列表中只会存在一个相同的UIAbility。
  • standard 启动模式:每次启动UIAbility都会创建一个新的实例。在任务列表中可能存在一个或多个相同的UIAbility
  • specified 启动模式:每个UIAbility实例可以设置key标识。启动UIAbility时,需要指定key,存在key相同实例直接被拉起,不存在则创建新实例。

1.当前UIAbility调用startAbility方法拉起目标UIAbility

// 1.1 获取上下文
context = getContext(this) as common.UIAbilityContext

// 1.2 指定要跳转到的UIAbility的信息
let want = {
  deviceId: '', // 为空表示本设备
  bundleName: 'com.example.myapplication',
  abilityName: 'DocumentAbility',
  moduleName: 'entry', // 非必选
  parameters: {
    // getInstanceKey: 自定义方法,生成目标UIAbility实例的key
    instanceKey: this.getInstanceKey()
  }
}

// 1.3 尝试拉起目标UIAbility实例
this.context.startAbility(want)

2.在AbilityStage的生命周期回调中为目标UIAbility实例生成key

export default class MyAbilityStage extends AbilityStage{
  onAcceptWant(want: Want): string {
    // 判断当前要拉取的是否是DocumentAbility
    if(want.abilityName === 'DocumentAbility'){
      // 根据参数中的instanceKey参数拼接生成一个key值并返回
      return `DocAbility_${want.parameters.instanceKey}`
    }
    return '';
  }
}

3.在module.json5配置文件中,通过srcEntry参数指定AbilityStage路径

{
  "module": {
    "name": "entry",
    "type": "entry",
    "srcEntry": "./ets/myabilitystage/MyAbilityStage.ts",
    ...
  }
}
### 软件开发中的 Stage 模型生命周期及其各阶段的作用 #### 生命周期概述 Stage 模型是一种现代化的软件开发生命周期模型,尤其适用于复杂的分布式系统开发环境。它不仅定义了清晰的开发流程,还强调模块化设计和组件化的实现方式。这种模型通常被应用于现代操作系统(如 HarmonyOS)的应用程序开发中[^2]。 在 Stage 模型中,整个生命周期可以分为多个关键阶段,每个阶段都具有特定的目标和职责。以下是其主要阶段以及它们的具体作用: --- #### 1. 需求分析阶段 此阶段的主要目标是对业务需求进行全面收集和整理,形成详细的文档描述。这是整个项目的基础,任何后续工作都需要依赖于这一阶段的结果。如果在此阶段未能充分理解客户需求,则可能导致后期频繁修改甚至失败的风险增加[^1]。 #### 2. 设计阶段 进入设计环节后,开发者需依据前一阶段确立的功能规格说明书来制定技术解决方案。对于采用 Stage 架构的产品而言,在这个过程中特别需要注意如何合理划分不同的 Ability 单元——比如区分哪些部分应该由 UIAbility 承担界面展示任务;而另一些后台服务逻辑则更适合交给 ExtensionAbility 来处理[^3]。 此外还需规划好各个模块之间的通信机制,确保数据能够高效准确地传输共享[^4]。 ```javascript // 示例:通过 Want 实现两个 Ability 的参数传递 let want = { bundleName: "com.example.myapp", abilityName: "SecondAbility" }; context.startAbility(want); ``` #### 3. 编码实施阶段 当设计方案得到确认之后便进入到实际编写代码的工作当中去了。按照预先设定好的接口标准分别去实现每一个单独的能力单元 (Ability),并保证他们之间可以通过标准化的方式相互协作互动起来。 值得注意的是,在 HarmonyOS 平台上的具体实践中,每当一个新的 UIAbility 实例被创建出来以后,紧接着就会经历一系列的状态转换过程,其中包括但不限于 Create -> Foreground 这样的典型路径变化轨迹等等。 ```python def create_ui_ability(): """ 创建一个简单的 UIAbility,并初始化窗口舞台。 """ window_stage_created = False def on_window_stage_create(window_stage): nonlocal window_stage_created window_stage.load_content("main_page.xml") # 加载页面布局文件 window_stage.on('windowStageEvent', handle_event) # 订阅事件 window_stage_created = True return on_window_stage_create ``` #### 4. 测试验证阶段 不同于传统的瀑布流模式仅允许线性的推进顺序执行各项操作步骤那样简单明了的做法,在这里由于引入了更多灵活性较高的特性支持的缘故所以相应也增加了不少复杂度方面的考量因素进来考虑范围之内。因此在整个测试期间除了常规意义上的功能性检测之外还需要额外关注跨平台兼容性表现情况等问题是否存在异常状况出现的可能性大小程度等方面的信息反馈回来作为最终评估结论的一部分组成部分之一加以利用参考价值所在之处体现得淋漓尽致。 #### 5. 发布部署阶段 一旦所有的前期准备工作都已经顺利完成并通过严格的质量检验体系认证合格之后就可以正式对外发布上线运行版本供广大用户群体下载安装体验试用了。与此同时为了保障系统的长期稳定可靠运转下去还会持续不断地对其进行优化改进升级维护等工作直至达到预期使用寿命期限为止才停止进一步的动作行为动作[^2]。 --- ### 总结 综上所述可以看出,stage 模型不仅仅只是单纯的一个理论框架概念而已,而是切实可行的一套完整的实践指南手册,帮助团队成员们更好地理解和遵循既定规则制度开展各项工作活动从而提高整体效率水平的同时降低潜在风险发生的概率几率大大减少不必要的麻烦困扰局面产生发展蔓延开来影响全局大局观瞻形象声誉受损严重后果不堪设想难以挽回弥补损失惨重代价高昂令人痛心疾首不已!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值