什么是不简单,把每一件简单的事情做好就是不简单;什么是不平凡?把每一件平凡的事情做好就是不平凡!
前言
鸿蒙应用开发已经成为互联网新的风口,开发鸿蒙软件已经成为今年工作的核心目标。在软件开发过程中,对于复杂度较大,功能较多的软件都会采用组件化项目架构,那么对于鸿蒙应用开发是否也能实现组件化呢?本文将详细讲解HarmonyOs组件化项目搭建的全过程,带领大家实现一个组件化项目。
项目创建
- 首先创建一个项目工程,点击开发工具DevEco-Stdio的File 选项,选择New 然后点击Create Project。
![](https://file.jishuzhan.net/article/1780065812644630529/6900820025166be39f77c4a92940e565.webp)
- 选择创建一个EmptyAbility,然后直接下一步,创建工程。
![](https://file.jishuzhan.net/article/1780065812644630529/def20c4de16cfbccb272e860c7b13638.webp)
- 工程主要包括一个entry模块,可以理解为Android的app主模块。
![](https://file.jishuzhan.net/article/1780065812644630529/969d7295f3f280cac075b14ec88636bf.webp)
公共库创建及使用
创建公共库Common组件。
- 在工程目录中,单机鼠标右键,选择New选项,然后在弹出的页面中选择Module。
![](https://file.jishuzhan.net/article/1780065812644630529/f43bda4409cf8ee742868d0175f1932c.webp)
- 在弹出的页面中,选择创建一个静态库Static Library。
![](https://file.jishuzhan.net/article/1780065812644630529/2458528dd81796844c3c8c0d16b768c3.webp)
- 然后点击Next,修改静态库的名称为common。
![](https://file.jishuzhan.net/article/1780065812644630529/f1453f3ca5e43e898586829bab87f21a.webp)
- 点击完成后,编译器会自动在项目的根目录的build-profile.json5文件中添加common模块。
![](https://file.jishuzhan.net/article/1780065812644630529/1bfb70ccab569d8d35af37132ed5380a.webp)
- 添加项目依赖,common作为公共库,需要提供给其他模块使用,这里以entry为例,添加模块依赖,如下图所示。
![](https://file.jishuzhan.net/article/1780065812644630529/d10a41bb1d89fed967d29a2db4ef9d51.webp)
- 至此,一个公共库common就创建完成了。
功能模块创建使用
一个功能复杂庞大的app不仅有公共模块,还有许多子模块构建而成。创建流程如下:
- 在工程目录中,单机鼠标右键,选择New选项,然后在弹出的页面中选择Module。
![](https://file.jishuzhan.net/article/1780065812644630529/74b14104f03ae7bfcc82e20fdd4cea1a.webp)
- 在弹出的页面中,选择创建一个共享库Shared Library。
![](https://file.jishuzhan.net/article/1780065812644630529/047647c34aef543875b1eddf67dd642c.webp)
- 然后点击Next,修改静态库的名称为login。
- 点击完成后,编译器会自动在项目的根目录的build-profile.json5文件中添加login模块。
![](https://file.jishuzhan.net/article/1780065812644630529/4db9d2a2327904e708dfe74188eb69a3.webp)
- 添加项目依赖,login作为子模块,需要被entry依赖调用,添加模块依赖,如下图所示。
![](https://file.jishuzhan.net/article/1780065812644630529/9528ef9faabdd7477783d104b414252b.webp)
- 到目前为止子模块也创建完成。
模块路由跳转
前面创建分别创建了公共库和子模块,如何从主模块entry跳转到子模块login,或者子模块之间互相跳转呢?
- HarmonyOs在页面跳转时提供了router实现路由跳转。需要跳转的目标页面必须满足两个条件,@Entry修饰struct 和路由注册。被@Entry修饰的struct才是一个独立页面。同时需要在main_pages.json中注册路由。
![](https://file.jishuzhan.net/article/1780065812644630529/39377456a7624249fd9e69a70acf12c7.webp)
- 在common中定义完整路径。不同子模块都会依赖公共静态库common。然后在common中定义目标页面的全路径。
![](https://file.jishuzhan.net/article/1780065812644630529/8dd7ca0fb418e8c93e72e9284084b668.webp)
全路径主要由三部分组成。分别是@bundle: 代表模版。 然后是 包名 com.cms.mmvm。最后是模块名+目标页面的全路径。
- 使用export关键字导出 ConstantRouter类,提供给其他模块调用。
![](https://file.jishuzhan.net/article/1780065812644630529/96bd9b0cd27b492b560403f42ef23cc6.webp)
- 引入ConstantRouter类,调用类中定义的路由。
![](https://file.jishuzhan.net/article/1780065812644630529/fe8a57cd8d91ef217c861c44e27f645a.webp)
总结
HarmonyOs组件化的使用,有利于模块之间的解耦及大型项目的共同开发。随着鸿蒙生态的不断完善,学习鸿蒙开发势必成为新的趋势。也是广大同行新的选择。
对于新的系统,学习开发过程中肯定会有难度,所以为了方便大家学习,解决开发过程中遇到的问题。感兴趣的小伙伴可以扫码进群,互相学习,互相成长!
![](https://file.jishuzhan.net/article/1780065812644630529/1eed2785c935ae475daf653ac73a1318.webp)