工程目录【详情见同名资源】

1. 工程级目录

工程的目录结构如下:

image-20240623140452496

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

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

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

image-20240623140756995

2. 模块级目录

默认entry是应用的主模块【此处为whatever,建项目时自定义】;

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

image-20240623140945623

main文件夹中,ets文件夹用于存放ets代码,resources文件存放模块内的多媒体及布局文件等,module.json5文件为模块的配置文件;

 * ohosTest是单元测试目录;
 ​
 * build-profile.json5是模块级配置信息,包括编译构建配置项;
 ​
 * hvigorfile.ts文件是模块级构建脚本;
 ​
 * oh-package.json5是模块级依赖配置信息文件;

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

image-20240623141505827

 * entryability存放ability文件,用于当前ability应用逻辑和生命周期管理;
 * pages存放UI界面相关代码文件,初始会生成一个Index页面;
 * resources目录下存放模块公共的多媒体、字符串及布局文件等资源,分别存放在element、media文件夹中。

3. app.json5

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

image-20240623141613203

 * bundleName是包名;
 * vendor是应用程序供应商;
 * versionCode是用于区分应用版本;
 * versionName是版本号。

4. module.json5

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

默认entry是应用的主模块【此处为whatever,建项目时自定义】;

image-20240623141759498

其中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启动页面的背景色。
visibleability是否可以被其他应用程序调用,true表示可以被其它应用调用, false表示不可以被其它应用调用。
skills标识能够接收的意图的action值的集合,取值通常为系统预定义的action值,也允许自定义。
entities标识能够接收的Want的Action值的集合,取值通常为系统预定义的action值,也允许自定义。
actions标识能够接收Want的Entity值的集合。

5. main_pages.json

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

  • 30
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值