第三节HarmonyOS DevEco Studio了解基本工程目录

一、工程级目录

工程的目录结构如下。

目录详情如下:

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

AppScope>resources>base中包含element和media两个文件夹:

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

二、模块级目录

entry>src目录中主要包含总的main文件夹,单元测试目录ohosTest,以及模块级的配置文件。

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

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

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

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

app.json5

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

  • bundleName:包名
  • vendor:应用程序供应商
  • versionCode:用于区分应用版本
  • versionName: 版本号
  • Icon:对应于应用的显示图标
  • label:应用名

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中对象的默认配置属性及描述:

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

main_pages.json

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

相关推荐
请叫我小蜜蜂同学2 小时前
【鸿蒙】鸿蒙操作系统发展综述
华为·harmonyos
HMS Core3 小时前
借助HarmonyOS SDK,《NBA巅峰对决》实现“分钟级启动”到“秒级进场”
华为·harmonyos
二二孚日3 小时前
自用华为ICT云赛道AI第一章知识点-机器学习概览
人工智能·华为
我科绝伦(Huanhuan Zhou)4 小时前
华为泰山服务器重启后出现 XFS 文件系统磁盘“不识别”(无法挂载或访问),但挂载点目录仍在且无数据
运维·服务器·华为
塞尔维亚大汉5 小时前
鸿蒙内核源码分析(文件句柄篇) | 你为什么叫句柄?
源码·harmonyos
别说我什么都不会5 小时前
【OpenHarmony】鸿蒙开发之FlexSearch
harmonyos
HarmonyOS小助手7 小时前
在鸿蒙中造梦的开发者,一边回答,一边前行
harmonyos·鸿蒙·harmonyos next·鸿蒙生态
刘阿宾8 小时前
【华为昇腾|CUDA】服务器A6000显卡部署LLM实战记录
服务器·华为·语言模型·gpu算力·kylin
HarmonyOS_SDK9 小时前
用AI重塑游戏体验:《诛仙2》携手HarmonyOS SDK实现性能与功耗双赢
harmonyos
别说我什么都不会9 小时前
【OpenHarmony】鸿蒙开发之epublib
harmonyos