Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
cfca21f3
D
Docs
项目概览
OpenHarmony
/
Docs
1 年多 前同步成功
通知
159
Star
292
Fork
28
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Docs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
cfca21f3
编写于
3月 02, 2023
作者:
O
openharmony_ci
提交者:
Gitee
3月 02, 2023
浏览文件
操作
浏览文件
下载
差异文件
!15361 【包管理】新增HAR共享包文档
Merge pull request !15361 from hanfeng/master
上级
3b8204d2
9ceea255
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
172 addition
and
0 deletion
+172
-0
zh-cn/application-dev/Readme-CN.md
zh-cn/application-dev/Readme-CN.md
+2
-0
zh-cn/application-dev/quick-start/har-package.md
zh-cn/application-dev/quick-start/har-package.md
+170
-0
未找到文件。
zh-cn/application-dev/Readme-CN.md
浏览文件 @
cfca21f3
...
...
@@ -25,6 +25,8 @@
-
[
多HAP使用规则
](
quick-start/multi-hap-rules.md
)
-
[
多HAP运行机制及数据通信方式
](
quick-start/multi-hap-principles.md
)
-
[
应用程序包安装和卸载流程
](
quick-start/application-package-install-uninstall.md
)
-
共享包
-
[
HAR共享包
](
quick-start/har-package.md
)
-
应用配置文件(Stage模型)
-
[
应用配置文件概述(Stage模型)
](
quick-start/application-configuration-file-overview-stage.md
)
-
[
app.json5配置文件
](
quick-start/app-configuration-file.md
)
...
...
zh-cn/application-dev/quick-start/har-package.md
0 → 100644
浏览文件 @
cfca21f3
# HAR共享包
## HAR共享包概述
HAR(OpenHarmony Archive)是OpenHarmony静态共享包,可以包含代码、C++库、资源和配置文件。通过HAR共享包,可以实现多个模块或多个工程共享ArkUI组件、资源等相关代码。HAR不同于HAP,不能独立安装运行在设备上,只能作为应用模块的依赖项被引用。
## 创建HAR模块
HAR包对应DevEco Studio工程中的“Library”类型的
[
Module
](
https://developer.harmonyos.com/cn/docs/documentation/doc-guides-V3/ohos-adding-deleting-module-0000001218760594-V3
)
,可以通过DevEco Studio创建一个HAR模块。HAR模块默认不开启混淆能力,开启混淆能力,需要把HAR模块的build-profile.json5文件中的artifactType字段设置为obfuscation,配置如下所示:
```
json
{
"apiType"
:
"stageMode"
,
"buildOption"
:
{
"artifactType"
:
"obfuscation"
}
}
```
artifactType字段有以下两种取值,默认缺省为original。
-
original:不混淆。
-
obfuscation:混淆,目前仅支持uglify混淆。
需要对代码资产进行保护时,建议开启混淆能力,混淆能力开启后,DevEco Studio在构建HAR时,会对代码进行编译、混淆及压缩处理,保护代码资产。
注意:artifactType字段设置为obfuscation时,apiType字段必须设置为stageMode,因为Stage模型才支持混淆。
## HAR共享包开发注意事项
-
HAR不支持在配置文件中声明ability、extensionAbility组件。
-
HAR不支持在配置文件中声明pages页面。
-
HAR不支持在build-profile.json5文件的buildOption中配置worker。
-
FA模型与Stage模型的HAR不支持相互引用。
-
Stage模型的HAR,不能引用AppScope内的内容。在编译构建时APPScope中的内容不会打包到HAR中,导致HAR资源引用失败。
## 导出HAR的ArkUI组件、接口、资源
index.ets文件是HAR共享包导出声明文件的入口,HAR共享包需要导出的接口,统一在index.ets文件中导出。index.ets文件是DevEco Studio默认自动生成的,用户也可以自定义,在模块的package.json文件中的main字段配置入口声明文件,配置如下所示:
```
json
{
"main"
:
"index.ets"
}
```
### 导出ArkUI组件
ArkUI组件的导出方式与ts的导出方式一致,通过
`export`
导出ArkUI组件,示例如下:
```
js
// library/src/main/ets/components/MainPage/MainPage.ets
@
Component
export
struct
MainPage
{
@
State
message
:
string
=
'
Hello World
'
build
()
{
Row
()
{
Column
()
{
Text
(
this
.
message
)
.
fontSize
(
50
)
.
fontWeight
(
FontWeight
.
Bold
)
}
.
width
(
'
100%
'
)
}
.
height
(
'
100%
'
)
}
}
```
HAR对外暴露的接口,在index.ets导出文件中声明如下所示:
```
js
// library/index.ets
export
{
MainPage
}
from
'
./src/main/ets/components/MainPage/MainPage
'
```
### 导出ts类和方法
通过
`export`
导出ts类和方法,支持导出多个ts类和方法,示例如下所示:
```
js
// library/src/main/ts/test.ets
export
class
Log
{
static
info
(
msg
)
{
console
.
info
(
msg
);
}
}
export
function
func
()
{
return
"
har func
"
;
}
export
function
func2
()
{
return
"
har func2
"
;
}
```
HAR对外暴露的接口,在index.ets导出文件中声明如下所示:
```
js
// library/index.ets
export
{
Log
}
from
'
./src/main/ts/test
'
export
{
func
}
from
'
./src/main/ts/test
'
export
{
func2
}
from
'
./src/main/ts/test
'
```
### 资源
HAR模块编译打包时会把资源打包到HAR包中。在编译构建HAP时,DevEco Studio会从HAP模块及依赖的模块中收集资源文件,如果不同模块下的资源文件出现重名冲突时,DevEco Studio会按照以下优先级进行覆盖(优先级由高到低):
-
AppScope(仅API9的Stage模型支持)。
-
HAP包自身模块。
-
依赖的HAR模块,如果依赖的多个HAR之间有资源冲突,会按照依赖顺序进行覆盖(依赖顺序在前的优先级较高)。
## 引用HAR的ArkUI组件、接口、资源
引用HAR共享包前,需要先配置对HAR的依赖,配置方式可
[
参考
](
https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ohos-development-npm-package-0000001222578434#section89674298391
)
。
### 引用HAR共享包的ArkUI组件
HAR共享包的依赖配置成功后,可以引用HAR共享包的ArkUI组件。ArkUI组件的导入方式与ts的导入方式一致,通过
`import`
引入HAR共享包导出的ArkUI组件,示例如下所示:
```
js
// entry/src/main/ets/pages/index.ets
import
{
MainPage
}
from
"
@ohos/library
"
@
Entry
@
Component
struct
Index
{
@
State
message
:
string
=
'
Hello World
'
build
()
{
Row
()
{
// 引用HAR共享包的ArkUI组件
MainPage
()
Column
()
{
Text
(
this
.
message
)
.
fontSize
(
50
)
.
fontWeight
(
FontWeight
.
Bold
)
}
.
width
(
'
100%
'
)
}
.
height
(
'
100%
'
)
}
}
```
### 引用HAR共享包的类和方法
通过
`import`
引用HAR共享包导出的ts类和方法,示例如下所示:
```
js
// entry/src/main/ets/pages/index.ets
import
{
Log
}
from
"
@ohos/library
"
import
{
func
}
from
"
@ohos/library
"
@
Entry
@
Component
struct
Index
{
build
()
{
Row
()
{
Column
()
{
Button
(
'
Button
'
)
.
onClick
(()
=>
{
// 引用HAR共享包的类和方法
Log
.
info
(
"
har msg
"
);
func
();
})
}
.
width
(
'
100%
'
)
}
.
height
(
'
100%
'
)
}
}
```
### 引用HAR共享包的资源
通过
`$r`
引用HAR共享包中的资源,例如在HAR模块的
`src/main/resources`
里添加字符串资源(在string.json中定义,name:hello_har)和图片资源(icon_har.png),然后在Entry模块中引用该字符串和图片资源的示例如下所示:
```
js
// entry/src/main/ets/pages/index.ets
@
Entry
@
Component
struct
Index
{
build
()
{
Row
()
{
Column
()
{
// 引用HAR共享包的字符串资源
Text
(
$r
(
"
app.string.hello_har
"
))
.
fontSize
(
50
)
.
fontWeight
(
FontWeight
.
Bold
)
// 引用HAR共享包的图片资源
Image
(
$r
(
"
app.media.icon_har
"
))
}
.
width
(
'
100%
'
)
}
.
height
(
'
100%
'
)
}
}
```
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录