HarmonyOS Next-三层架构之项目引用har包实战

废话不多说,首先我们从官网了解下分层架构设计-三层架构:

链接:developer.huawei.com/consumer/cn...

分层架构逻辑模型:

下面以项目为例-实现在 Personal.ets页面 中引用 feature 中mine的har组件并展示:

1.在feature/mine/src/main/ets/components/MainPage.ets新建一个har组件:

javascript 复制代码
@Component
export struct MainPage {
  @State message: string = 'mine---Hello World';

  build() {
    Row() {
      Column() {
        Text(this.message)
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
      }
      .width('100%')
    }
    .height('100%')
  }
}

2.需要在 product/phone 的 oh-package.json5 中添加对feature/mine 的依赖

javascript 复制代码
{
  "name": "phone",
  "version": "1.0.0",
  "description": "Please describe the basic information.",
  "main": "",
  "author": "",
  "license": "Apache-2.0",
  "dependencies": {
    "@ohos/mine": "file:../../features/mine"  // 添加这一行
  }
}

3.然后在feature/mine中导出需要的组件

javascript 复制代码
// 导出所有需要的组件
export { MainPage } from './src/main/ets/components/MainPage'

4.最后在 Personal.ets 中导入并使用组件

javascript 复制代码
import { MainPage } from 'mine'  // 导入 feature/mine 中的组件

@Entry
@Component
export struct Personal {
  build() {
    Stack() {
      Navigation() {
        List() {
          ListItem() {
            // 使用 feature/mine  中的 MainPage 组件
            MainPage()
          }
        }
        .padding({ left: 12, right: 12 })
        .width('100%')
        .height('100%')
        .backgroundColor(Color.White)
      }
    }
  }
}

项目目录结构如下:

展示效果如下图:

这个就展示到这里了,大家觉得有用处的话就帮忙点点赞!

相关推荐
Mr.闻吉安10 分钟前
什么是变量提升?
javascript·es6
huohuopro20 分钟前
Vue3快速入门/Vue3基础速通
前端·javascript·vue.js·前端框架
草巾冒小子21 分钟前
vue3中解决 return‘ inside ‘finally‘ block报错的问题
前端·javascript·vue.js
MossGrower1 小时前
65.Three.js案例-使用 MeshNormalMaterial 和 MeshDepthMaterial 创建 3D 图形
javascript·threejs·spheregeometry·torusknotgeome
-Camellia007-6 小时前
TypeScript学习案例(1)——贪吃蛇
javascript·学习·typescript
GoFly开发者6 小时前
GoFly企业版框架升级2.6.6版本说明(框架在2025-05-06发布了)
前端·javascript·vue.js
Java开发追求者7 小时前
base64与图片的转换和预览(高阶玩法)
javascript·html·base64与图片的转换和预览·高阶玩法
GanGuaGua7 小时前
CSS:元素显示模式与背景
前端·javascript·css·html
一个会的不多的人7 小时前
C# NX二次开发:判断两个体是否干涉和获取系统日志的UFUN函数
前端·javascript·html
油丶酸萝卜别吃7 小时前
git的常用命令详解
开发语言·javascript·ecmascript