【坚果派】JS 开源库适配 OpenHarmony 系列——第一期实操
data:image/s3,"s3://crabby-images/f55d7/f55d701cc100a110f04f0ee01109ca30f338ae0e" alt="【坚果派】JS开源库适配OpenHarmony系列——第一期实操"
data:image/s3,"s3://crabby-images/d8cce/d8cce0306c5db91293a4a377d91ae5bdba71e36b" alt=""
1. 为什么适配 JS 开源库
由于 OpenHarmony 应用是基于 ArkTS 开发,而 ArkTS 是在保持 TypeScript(简称 TS)基础语法风格的基础上,对 TS 的动态类型特性施加更严格的约束,引入静态类型。因此在开发 OpenHarmony 三方库时,建议首选在成熟的 JS/TS 开源三方库上开发。
2. 选择哪个 JS 开源库合适
JS/TS 开源三方库的选择需遵循易用性、实用性、维护性、扩展性等特性,通常方法是在 github/npm 上按照特性和语言搜索,找到 star、fork 数量较高的,且开源协议友好的 JS/TS 开源三方库进行适配。
3. 如何进行 JS 开源库适配
由于 OpenHarmony 开发框架中的 API 不完全兼容 V8 运行时的 Build-In API,因此建议在适配 JS 三方库前,使用js-e2e扫描三方库,检查是否存在 node.js/web 内置模块的依赖。
js-e2e 工具时基于 eslint 进行封装,可分析出 JS 库代码对 node.js/web 浏览器的内置模块、对象的依赖及兼容 ES 标准版本,使用该工具,可以快速知道该库是否依赖 node.js/web 内置模块。
如果扫描结果不依赖 node.js/web 内置模块,那么,这个库将比较轻松地适配。如果大量依赖 node.js/web 内置组件,这时可能需要 fork 源库代码,进行侵入式修改,或者再找是否存在更适合的其他三方库。
注:扫描时需同时扫描 package.json 文件中 dependencies 标签中直接依赖和间接依赖,因为发布 OpenHarmony 三方库中心仓时,需要将依赖的组件都发布。建议使用 npm insall 下载所有依赖的代码后,一起扫描查看结果。
3.1 luxon 开源库信息
在 npm 中心仓库查看用于处理日期和时间的目标库 luxon 信息,包括开源仓库地址,主页地址,版本,协议,文件大小,总文件数,最后发布时间等。
data:image/s3,"s3://crabby-images/af3b0/af3b0acdd401abedb8934ed7f753c2a9c80bf139" alt=""
在 OpenHarmony 中心仓搜索是否存在 luxon 目标库。
data:image/s3,"s3://crabby-images/67a7b/67a7ba87c78ad7d44a854753981f5933e80f9063" alt=""
在 luxon 源代码仓库查看 star 和 fork 数量,查看是否被经常使用和经常被维护。
luxon 仓库:https://github.com/moment/luxon
data:image/s3,"s3://crabby-images/67364/6736467ade351ad3a4f0b8eda1312f59817f4b82" alt=""
3.2 JS 三方库扫描工具介绍
js-e2e 是基于 eslint 进行封装、配置规则,用于分析 JS 库代码对 NodeJS 和 Web 浏览器的内置模块、对象的依赖及兼容 ES 标准版本的工具,支持检查指定源码目录和指定三方库的兼容性。
3.2.1 使用 git 工具同步 js-e2e 代码
data:image/s3,"s3://crabby-images/59d8f/59d8f873fd78ba3385e9b09b8d7fe2c5e6133660" alt=""
3.2.2 安装 npm 依赖包
data:image/s3,"s3://crabby-images/1f4f3/1f4f384a97fff1b3ced5b63940a7fa67a96c74a5" alt=""
3.2.3 安装自定义的 eslint 输出报告 formatter,包含 csv、csvsimple、vscode、vscodesimple
data:image/s3,"s3://crabby-images/332d9/332d9d3204eda5456c06c4a5988aa826d14fc67e" alt=""
3.2.4 执行检查命令
data:image/s3,"s3://crabby-images/3bb28/3bb281b93a072ad6c46be5bf4c7f09f734166efb" alt=""
3.3 适配 luxon 三方库
使用 DevEco Studio 开发者工具,创建 OpenHarmony 应用工程。
data:image/s3,"s3://crabby-images/58e36/58e36d77c492022029e56704563b6a79e17b732a" alt=""
在工程中新建 Module,选择“Static Library”模板。
data:image/s3,"s3://crabby-images/d4eba/d4eba8f56063e9f87780a0bc74d760b025be2b66" alt=""
移除 library 模块 src/main/ets 目录中的 components 目录,删除 Index.ets 文件中的代码。
直接复制 js-e2e 工具检查时下载的 luxon 包(temp/node_modules/luxon),并将 src 目录中的文件复制到 library 模块的 src/main/ets/lib 目录下。
data:image/s3,"s3://crabby-images/0f953/0f95319402a597662496137c0941b36cf4b74ce2" alt=""
5)修改 Index.ets 文件为其他开发者提供调用接口。
data:image/s3,"s3://crabby-images/dba5e/dba5e9b45e11d68e5cae63049d6fe2e52a04de86" alt=""
在 oh-package.json5 中完善三方库信息,如名称、简介、版本、开源协议、作者、关键字等。
data:image/s3,"s3://crabby-images/b759c/b759cc5067df8cdde488ef35ced5d9ae97d521d0" alt=""
在工程目录中选中三方库名称,单击菜单栏中的 Build > Make Module ‘library’编译构建生成三方库 HAR 包,HAR 包可在模块下的 build 目录下获取,包格式为*.har。
data:image/s3,"s3://crabby-images/85b0f/85b0fb2eb73faebbe15e4bccf46774828097fd1e" alt=""
3.4 验证 luxon 三方库
打开 entry/oh-package.json5 配置文件,在 dependencies 标签中引入 luxon 三方库,并单击 Sync Now 进行同步。
data:image/s3,"s3://crabby-images/c9b9e/c9b9e5b264fe233e88088b38fe6df7e3550b6fb9" alt=""
打开 pages/Index.ets 页面文件,引入 luxon 三方库并显示当前日期。
data:image/s3,"s3://crabby-images/01883/01883c7138ea0be3bcd9186c8ba5896cbaff8e7f" alt=""
至此,简单的 JS 开源三方库适配 OpenHarmony 已经完成了,下节我们将推出如何将讲解如何进行 XTS 测试,OpenHarmony 三方库发布标准,适配的三方库发布到 OpenHarmony 三方库中心仓以及如何贡献到 OpenHarmony-TPC。
版权声明: 本文为 InfoQ 作者【白晓明】的原创文章。
原文链接:【http://xie.infoq.cn/article/c45dfb08a5efecd8ac7e0ff05】。
本文遵守【CC BY-NC-SA】协议,转载请保留原文出处及本版权声明。
评论