鸿蒙应用开发-我的第一个三方库

前言

  1. 鸿蒙应用使用ArkTS进行开发,ArtTS是基于TS进行扩展,添加一些类型限制,TS只是给JS添加了静态类型系统,最终编译完成的JS其实是把类型去掉了的
  2. 前端JS发展这么多年积累了很多非常好用的工具库,把这些工具库迁移到鸿蒙中会给我们开发带来很大的助力
  3. 鸿蒙三方库都是Har包,JS的工具库不能简单的迁移过来,需要做一些改动

准备工作

  1. 我们首先需要有一个鸿蒙三方库的账号,如果没有,进入这个地址进行注册 ohpm.openharmony.cn/#/cn/home
  2. 配置好访问三方库的公钥地址在这 ohpm.openharmony.cn/#/cn/person...
  3. 在个人中心添加你的公钥和获取发布码用于发布三方库到库中心

4. 在用户目录 ~/.ohpm/.ohpmrc里面配置好发布码和私钥路径

开发

说明

我的第一个库是基于 github.com/niksy/throt... v5.0.0版本 进行封装和完善的

js-e2e扫描三方库

鸿蒙是基于OpenHarmony开发的,框架中的API没有完全兼容V8运行时的内置API,我们需要使用js-e2e扫描三方库,检查是否存在node.js/web内置模块的依赖。

js-e2e工具是基于eslint进行封装,可分析出JS库代码对node.js/web浏览器的内置模块、对象的依赖及兼容ES标准版本,使用该工具,可以快速知道该库是否依赖node.js/web内置模块

步骤

下载库 git clone <[email protected]>:chenwenjiehw/js-e2e.git

进入下载仓库,安装依赖

执行 npm run mklink 安装输出文档的格式

执行 node checker.js -p throttle-debounce 检查npm包

创建Har包

创建一个空Ability的工程

在工程目录右键 新建→ 模块 或者 点击菜单栏文件 新建→ 模块,选择Static Library

将新建模块 src/main/ets/components删除,并且把Index.ets文件中的代码一并删除

将debounce和throttle代码拷贝到 src/main/ets目录下,当然如果你也可以自己定义一个lib目录,将代码拷贝进去

修改Index.ets代码,将必要的文件导出

在oh-package.json5中完善三方库信息,如名称、简介、版本、开源协议、作者、关键字等

在模块根目录添加CHANGELOG.md 版本变更记录、README.md 简介,安装方式等、LICENSE、example样例 等必要文件

将工程的构建模式修改为release

在工程目录中选中三方库名称,单击菜单栏中的Build > Make Module 'library'编译构建生成三方库HAR包,HAR包可在模块下的build目录下获取,包格式为*.har

验证功能

打开entry/oh-package.json5配置文件,在dependencies标签中引入@unravel/throttle-debounce三方库,并单击Sync Now进行同步 或者 打开终端执行 ohpm install命令

打开pages/Index.ets页面文件,引入并调用debounce和throttle方法进行限频

发布

打开菜单 视图->工具窗口→终端 打开终端应用

在终端 输入 ohpm publish har包的路径,发布到三方库

打开鸿蒙三方库中心仓的地址,切换到package。上面有审核状态等,后续关注信息就可以了 ohpm.openharmony.cn/#/cn/person...

搜索使用

打开三方库中心库 地址 ohpm.openharmony.cn/#/cn/home

在搜索框中输入我们发布成功的库 throttle_debounce就可以看到结果了

点击进去之后,可以查看具体的使用方式说明

参考资料

  1. JS开源库适配纯血鸿蒙 mp.weixin.qq.com/s/9qZWN6Y_R...
  2. 鸿蒙三方库中心仓 ohpm.openharmony.cn/#/cn/home
  3. 创建及发布三方库 ohpm.openharmony.cn/#/cn/help/c...
相关推荐
__Benco15 分钟前
OpenHarmony外设驱动使用 (四),Face_auth
人工智能·驱动开发·计算机视觉·harmonyos
bestadc20 分钟前
鸿蒙 系统-安全-程序访问控制-应用权限管控
harmonyos
IT小码哥丶29 分钟前
HarmonyOS实战:快速实现一个上下滚动的广告控件
华为·harmonyos
幽蓝计划3 小时前
Uniapp开发鸿蒙应用时如何运行和调试项目
华为·uni-app·harmonyos
魔术师ID10 小时前
HarmonyOS开发组件基础
华为·harmonyos
周胡杰14 小时前
组件导航 (Navigation)+flutter项目搭建-混合开发+分栏
数码相机·flutter·华为·电脑·harmonyos·鸿蒙
特立独行的猫a19 小时前
HarmonyOS 影视应用APP开发--配套的后台服务go-imovie项目介绍及使用
华为·golang·harmonyos·影视app
梁下轻语的秋缘21 小时前
HarmonyOS:重构万物互联时代的操作系统范式
华为·重构·harmonyos
lpfasd12321 小时前
Flutter与Kotlin Multiplatform(KMP)深度对比及鸿蒙生态适配解析
flutter·kotlin·harmonyos
交叉编译之王 hahaha1 天前
OpenHarmony 5.1.0 Release目录结构详细解析(3级目录)
arm开发·华为·harmonyos