一、场景描述

共享包选型:应用模块化选型

伙伴开发过程中可能会遇到共享包转型场景,主要有hsp转har包和har转hsp包两种情况,由此经常要求提供har和hsp转换方案。共享包转换核心思路就是将配置文件统一,比如将hsp支持的配置文件转换为har的配置文件,主要涉及module.json5、hvigorfile.ts、build-profile.json5文件,以及路由方式切换等场景。

二、方案描述

场景一:hsp转har包

提供方hsp包转换

1.在hsp下的module.json5中,把"type": "shared"修改为"type": "har",删除"deliveryWithInstall"、"pages"字段。

zh-cn_image_0000001903812330.png

2.由于har中不能声明page,需要先删除原hsp中module.json5的page声明;har不能用router.pushurl路由方式,需要修改原有router.pushurl路由为navigation(推荐)或命名路由跳转方式,以navigation为例,使用组件导航的demo如下:

zh-cn_image_0000001940811753.png

** ** 左entry中Index页面,右har1中pageOne页面

①router变navigation方式详见Navigation应用适配指南第三点Router对应适配修改:router切换navigation适配指南

②若沿用router的方式,需要使用命名路由的方式,可参考官网指南:命名路由

3.然后再找到hsp下的hvigorfile.ts文件,将里面的hspTasks改为harTasks。

zh-cn_image_0000001903652418.png

**4.(可选)如需要指定该library被依赖时的混淆规则(该项仅har模块可配置,详情可见**[consumerFiles属性介绍]),可在build-profile.json5添加配置"consumerFiles": './consumer-rules.txt' 。

001.png

5.清理重新安装打包(clean——\>build)

引用方引用har包

转化前引用hsp包:

002.png

转换后引用har包:

源码方式依赖:

003.png

将产物har包放到引用模块下依赖:

004.png

场景二:har转hsp包

提供方har包转换

1.在har下的module.json5中,把"type": "har"修改为"type": "shared",添加"deliveryWithInstall"。

005.png

2.(可选)当Hsp需要对外声明router可跳转的page时,需要添加module.json5的"pages"字段,并在resources/base目录下建立profile/main\_pages.json文件,添加配置参考如下,并在对应位置添加页面。

006.png

3.再找到har下的hvigorfile.ts文件,将里面的harTasks改为hspTasks。

007.png

4.har包的build-profile.json5默认会有"consumerFiles": './consumer-rules.txt' ,该项仅har模块可配置,为默认导出的混淆规则(详细描述见:代码混淆),需将其删除。

008.png

5.清理重新安装打包(clean——\>build)

引用方引用hsp包

转换前引用har包:

009.png

转换后引用hsp包:

010.png


HarmonyOS码上奇行
7.5k 声望2.9k 粉丝