3g微网站,长沙网站制作案例,如何申请企业邮箱帐号,商城网站建设是 什么软件共享包概述
OpenHarmony提供了两种共享包#xff0c;HAR#xff08;Harmony Archive#xff09;静态共享包#xff0c;和HSP#xff08;Harmony Shared Package#xff09;动态共享包。
HAR与HSP都是为了实现代码和资源的共享#xff0c;都可以包含代码、C库、资源和配…共享包概述
OpenHarmony提供了两种共享包HARHarmony Archive静态共享包和HSPHarmony Shared Package动态共享包。
HAR与HSP都是为了实现代码和资源的共享都可以包含代码、C库、资源和配置文件最大的不同之处在于HAR中的代码和资源跟随使用方编译如果有多个使用方它们的编译产物中会存在多份相同拷贝而HSP中的代码和资源可以独立编译运行时在一个进程中代码也只会存在一份。
图1 HAR和HSP在APP包中的形态示意图 HSP旨在解决HAR存在的几个问题
多个HAP引用相同的HAR导致的APP包大小膨胀问题。多个HAP引用相同的HARHAR中的一些状态变量无法共享的问题。
HSP的一些约束
HSP及其使用方都必须是Stage模型。HSP及其使用方都必须使用esmodule编译模式。HSP不支持在配置文件中声明abilities、extensionAbilities标签。
HSP按照使用场景可以分为应用内HSP和应用间HSP应用间HSP暂不支持。
HAR
mony Archive是静态共享包可以包含代码、C库、资源和配置文件。通过HAR可以实现多个模块或多个工程共享ArkUI组件、资源等相关代码。HAR不同于HAP不能独立安装运行在设备上只能作为应用模块的依赖项被引用。
创建HAR模块
HAR对应DevEco Studio工程中的“Library”类型的Module可以通过DevEco Studio创建一个HAR模块。HAR模块默认不开启混淆能力开启混淆能力需要把HAR模块的build-profile.json5文件中的artifactType字段设置为obfuscation配置如下所示
{apiType: stageMode,buildOption: {artifactType: obfuscation}
}artifactType字段有以下两种取值默认缺省为original。
original不混淆。obfuscation混淆目前仅支持uglify混淆。
需要对代码资产进行保护时建议开启混淆能力混淆能力开启后DevEco Studio在构建HAR时会对代码进行编译、混淆及压缩处理保护代码资产。
注意artifactType字段设置为obfuscation时apiType字段必须设置为stageMode因为Stage模型才支持混淆。
HAR开发注意事项
HAR不支持在配置文件中声明abilities、extensionAbilities组件。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默认自动生成的用户也可以自定义在模块的oh-package.json5文件中的main字段配置入口声明文件配置如下所示
{main: index.ets
}导出ArkUI组件
ArkUI组件的导出方式与ts的导出方式一致通过export导出ArkUI组件示例如下
// library/src/main/ets/components/MainPage/MainPage.ets
Component
export struct MainPage {State message: string Hello Worldbuild() {Row() {Column() {Text(this.message).fontSize(50).fontWeight(FontWeight.Bold)}.width(100%)}.height(100%)}
}HAR对外暴露的接口在index.ets导出文件中声明如下所示
// library/index.ets
export { MainPage } from ./src/main/ets/components/MainPage/MainPage导出ts类和方法
通过export导出ts类和方法支持导出多个ts类和方法示例如下所示
// 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导出文件中声明如下所示
// 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的依赖配置方式可参考。
引用HAR的ArkUI组件
HAR的依赖配置成功后可以引用HAR的ArkUI组件。ArkUI组件的导入方式与ts的导入方式一致通过import引入HAR导出的ArkUI组件示例如下所示
// entry/src/main/ets/pages/index.ets
import { MainPage } from ohos/libraryEntry
Component
struct Index {State message: string Hello Worldbuild() {Row() {// 引用HAR的ArkUI组件MainPage()Column() {Text(this.message).fontSize(50).fontWeight(FontWeight.Bold)}.width(100%)}.height(100%)}
}引用HAR的类和方法
通过import引用HAR导出的ts类和方法示例如下所示
// entry/src/main/ets/pages/index.ets
import { Log } from ohos/library
import { func } from ohos/libraryEntry
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中定义namehello_har和图片资源icon_har.png然后在Entry模块中引用该字符串和图片资源的示例如下所示
// 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%)}
}
串资源Text($r(app.string.hello_har)).fontSize(50).fontWeight(FontWeight.Bold)// 引用HAR的图片资源Image($r(app.media.icon_har))}.width(100%)}.height(100%)}
}