【HarmonyOSNext应用开发全攻略】从包结构解析到上架部署一站式指南
Harmony OS Next ##Ark Ts ##教育
本文适用于教育科普行业进行学习,有错误之处请指出我会修改。
📦 一、应用与应用程序包小课堂
1️⃣ 什么是应用?
👉 就是你在手机/平板上用的各种App啦!比如微信、抖音这些~
2️⃣ 应用程序包是啥?
👉 相当于App的"安装包",后缀是.hap/.hsp/.har这些格式
3️⃣ 系统超贴心功能:
✅ 跨芯片支持(x86/ARM通吃!)
✅ 全生命周期管理(安装/更新/卸载一条龙)
✅ 开发者只需专注功能实现
🔧 二、超实用的多Module设计
🚀 为什么需要多Module?
▸ 场景1:模块化开发
把不同功能拆分成独立Module(比如登录模块、支付模块),就像乐高积木一样自由组合!
▸ 场景2:多设备适配
不同Module可以标注支持的设备类型,系统会智能匹配:
// 示例:配置支持设备类型
"deviceTypes": ["phone", "tablet"]
🎁 三、Module类型大揭秘
💎 Ability类型Module(生成.hap文件)
类型 | 功能说明 | 数量限制 |
---|---|---|
entry | 主模块!包含启动图标和核心功能 | 同类设备仅1个 |
feature | 动态扩展功能模块 | 不限量 |
📚 Library类型Module(共享代码神器)
类型 | 文件后缀 | 特点说明 |
---|---|---|
Static | .har | 静态共享,多处引用会重复打包 |
Shared | .hsp | 动态共享,进程内只存一份 |
⚠️ 超重要提醒:
开发HAR时记得开启混淆保护代码!在build-profile.json里配置:
"buildTypes": [{
"name": "release",
"proguard": true
}]
🌈 四、HAR vs HSP终极对比表
编译方式 | 运行方式 | 发布范围 | |
---|---|---|---|
HAR | 随使用方编译,多副本存在 | 静态加载 | 跨应用可用 |
HSP | 独立编译,单副本运行 | 动态加载 | 应用内/集成态可用 |
💡 小贴士:
HSP开发时会同时生成.hsp和.har文件,后者是接口文件哦~ 就像奶茶的吸管和杯盖都要有才能喝到!🥤
📂 一、开发态包结构大拆解
👉 创建项目后你的工程会长这样:
MyProject/
├── AppScope/ # 系统自动生成❗不可修改
│ ├── app.json5 # 应用全局配置(名字/图标等)
│ └── resources/ # 全应用共享资源
└── Module_name/ # 你的功能模块(可自定义命名)
├── src/main/
│ ├── ets/ # 代码主战场💻
│ ├── resources/ # 模块专属资源
│ └── module.json5 # 模块身份证(设备类型/权限等)
└── 构建家族文件:
├── build-profile.json5 # 构建配置(签名/产品配置)
├── hvigorfile.ts # 构建任务指挥官⚙️
├── obfuscation-rules.txt# 代码保护盾🛡️(混淆规则)
└── oh-package.json5 # 依赖库清单📦
🔨 二、编译魔法时刻
从开发态到编译态的神奇变化:
// 编译前
ets/ → .ets文件
resources/ → 原始资源
// 编译后 🔮
ets/ → .abc文件(字节码)
resources/ → 合并AppScope资源(同名文件AppScope优先)
⚠️ 重要规则:
- 多个HAR会被直接打包进HAP/HSP
- 模块配置文件会融合AppScope的全局配置
🚚 三、发布上架全流程
1️⃣ 打包成.app文件(应用市场专用)
2️⃣ 自动生成pack.info(内含所有模块信息)
3️⃣ 应用市场分发时:
graph TD
A[用户下载.app] --> B[云端拆解HAP/HSP]
B --> C[设备端按需安装]
📦 四、三大包类型终极对比
能力维度 | HAP | HAR | HSP |
---|---|---|---|
独立安装运行 | ✅ | ❌ | ❌ |
声明UI组件 | ✅ | ❌ | ❌ |
包含资源文件 | ✅ | ✅ | ✅ |
依赖其他共享包 | ✅ | ✅ | ✅ |
💡 隐藏技巧:
// HAR也可以包含页面!用命名路由跳转:
router.pushUrl({ name: 'harPage' })
⚠️ 避坑指南:
- HAR如果依赖了HSP → 只能应用内使用❗
- 禁止循环依赖和依赖传递🔄
- 开发HAR必开混淆保护:
// build-profile.json5
"buildTypes": [{
"name": "release",
"proguard": true // 开启保护模式🔒
}]
🌈 五、选包策略速查表
使用场景 | 推荐方案 | 优点 |
---|---|---|
基础功能模块 | HAP | 独立运行,功能完整 |
跨团队代码复用 | HAR | 支持发布到三方仓库📤 |
多模块共享相同代码 | HSP | 节省空间,动态加载⚡ |
需要声明UI组件 | HAP | 唯一支持类型🎨 |
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。