头图

【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[设备端按需安装]

📦 四、三大包类型终极对比

能力维度HAPHARHSP
独立安装运行
声明UI组件
包含资源文件
依赖其他共享包

💡 隐藏技巧:

// HAR也可以包含页面!用命名路由跳转:
router.pushUrl({ name: 'harPage' })

⚠️ 避坑指南:

  1. HAR如果依赖了HSP → 只能应用内使用❗
  2. 禁止循环依赖和依赖传递🔄
  3. 开发HAR必开混淆保护:
// build-profile.json5
"buildTypes": [{
  "name": "release",
  "proguard": true // 开启保护模式🔒
}]

🌈 五、选包策略速查表

使用场景推荐方案优点
基础功能模块HAP独立运行,功能完整
跨团队代码复用HAR支持发布到三方仓库📤
多模块共享相同代码HSP节省空间,动态加载⚡
需要声明UI组件HAP唯一支持类型🎨

Turing_010
1 声望0 粉丝