写点什么

深度剖析 OpenHarmony 应用 / 服务的逻辑结构

作者:Anna
  • 2022 年 4 月 29 日
  • 本文字数:1832 字

    阅读完需:约 6 分钟

深度剖析OpenHarmony应用/服务的逻辑结构

OpenHarmony APP 工程结构在进行 OpenHarmony 应用/服务开发前,应该掌握 OpenHarmony 应用/服务的逻辑结构。OpenHarmony 应用/服务发布形态为 APP Pack(Application Package,简称 APP),它是由一个或多个 HAP(OpenHarmony Ability Package)包以及描述 APP Pack 属性的 pack.info 文件组成。一个 HAP 在工程目录中对应一个 Module,它是由代码、资源、第三方库及应用/服务配置文件组成,可以分为 Entry 和 Feature 两种类型。Entry:应用/服务的主模块,可独立安装运行。在一个工程中同一个设备类型只支持一个 Entry 类型的模块。Feature:应用/服务的动态特性模块。一个 APP 可以包含一个或多个 feature 类型的 HAP,也可以不含。HAP 是 Ability 的部署包,OpenHarmony 应用/服务代码围绕 Ability 组件展开,它是由一个或多个 Ability 组成。Ability 分为两种类型:FA(Feature Ability,中文名称:元程序)和 PA(Particle Ability,中文名称:元服务)。FA/PA 是应用/服务的基本组成单元,能够实现特定的业务功能。FA 有 UI 界面,而 PA 无 UI 界面。

工程目录结构 eTS 工程目录结构

entry:OpenHarmony 工程模块,编译构建生成一个 Hap 包。src > main > ets:用于存放ets 源码。src > main > ets > MainAbility:应用/服务的入口。src > main > ets > MainAbility > pages:MainAbility 包含的页面。src > main > ets > MainAbility > app.ets:承载 Ability 生命周期。src > main > resources:用于存放应用/服务所用到的资源文件,如图形、多媒体、字符串、布局文件等。

src > main > config.json:模块配置文件,主要包含 HAP 包的配置信息、应用在具体设备上的配置信息以及应用的全局配置信息。build-profile.json5:当前的模块信息、编译信息配置项,包括 buildOption、targets 配置等。hvigoRFile.js:模块级编译构建任务脚本,开发者可以自定义相关任务和代码实现。build-profile.json5:应用级配置信息,包括签名、产品配置等。hvigorfile.js:应用级编译构建任务脚本。JS 工程目录结构

entry:OpenHarmony 工程模块,编译构建生成一个 Hap 包。src > main > js:用于存放 js 源码。src > main > js > MainAbility:应用/服务的入口。src > main > js > MainAbility > i18n:用于配置不同语言场景资源内容,比如应用文本词条、图片路径等资源。src > main > js > MainAbility > pages:MainAbility 包含的页面。src > main > js > MainAbility > app.js:承载 Ability 生命周期。src > main > resources:用于存放应用/服务所用到的资源文件,如图形、多媒体、字符串、布局文件等。

src > main > config.json:模块配置文件,主要包含 HAP 包的配置信息、应用在具体设备上的配置信息以及应用的全局配置信息。entry > build-profile.json5:当前的模块信息、编译信息配置项,包括 buildOption、targets 配置等。entry > hvigorfile.js:模块级编译构建任务脚本,开发者可以自定义相关任务和代码实现。build-profile.json5:应用级配置信息,包括签名、产品配置等。hvigorfile.js:应用级编译构建任务脚本。C++工程目录结构

entry:OpenHarmony 工程模块,编译构建生成一个 Hap 包。src > main > cpp > types:用于存放 C++的 API接口描述文件 src > main > cpp > types > libhello > index.d.ts:描述 C++ API 接口行为,如接口名、入参、返回参数等。src > main > cpp > types > libhello > package.json:配置.so 三方包声明文件的入口及包名。src > main > cpp > CMakeLists.txt:CMake 配置文件,提供 CMake 构建脚本。src > main > cpp > hello.cpp:定义 C++ API 接口的文件。src > main > ets:用于存放 ets 源码。src > main > resources:用于存放应用/服务所用到的资源文件,如图形、多媒体、字符串、布局文件等。

entry > src > main > config.json:模块配置文件,主要包含 HAP 包的配置信息、应用在具体设备上的配置信息以及应用的全局配置信息。entry > build-profile.json5:当前的模块信息、编译信息配置项,包括 buildOption、targets 配置等。entry > hvigorfile.js:模块级编译构建任务脚本,开发者可以自定义相关任务和代码实现。build-profile.json5:应用级配置信息,包括签名、产品配置等。hvigorfile.js:应用级编译构建任务脚本。


原文转载链接:https://i.openharmony.cn/AZ9CMqdS

用户头像

Anna

关注

华为鸿蒙运营 2022.01.21 加入

如果对OpenHarmony感兴趣或喜欢参加线上活动,欢迎加我微信cuijiansy拉您进开发者交流群

评论

发布
暂无评论
深度剖析OpenHarmony应用/服务的逻辑结构_OpenHarmony_Anna_InfoQ写作社区