news 2026/4/16 15:45:40

Hvigor 构建自动化部署脚本(二) 自定义Hvigor任务

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Hvigor 构建自动化部署脚本(二) 自定义Hvigor任务

自定义任务介绍


  • 创建一个自定义任务工程,并且实现一个基础的任务流程

  • 将自定义任务注册到harmony工程中的module中并执行

1、创建自定义任务工程


  • 安装相应的nodejs与npm(可以用安装环境后默认自带的node环境)
  • 安装typescript环境(npm install -g typescript)
  • 新建一个harmony工程,并且在工程内创建两个演示module,以及一个Hvigor的plugin工程,并且在plugin目录下通过tsc --init和npm init初始化node工程,通过npm命令行安装hvigor 与 hvigor-ohos-plugin(安装前需要添加.npmrc文件,详情可参考 Hvigor 构建自动化部署脚本(一) Hvigor介绍以及使用)
    npm install @ohos/hvigor npm install @ohos/hvigor-ohos-plugin
    完成后工程目录结构为下图所示:


    我们可以直接用vscode将plugin工程打开,并且创建我们自定义任务,工程结构如下:


    自定义任务需要实现HvigorTask接口,并且实现内部的方法,接口详情如下:
export interface HvigorTask { /** * 任务名称,全局唯一 */ name: string; /** * task 上下文 */ context?: (() => any) | any; /** * Task 定义增量输入接口 * * @param input */ input?: (input: TaskInput) => void; /** * task 定义增量输出接口 * * @param output */ output?: (output: TaskOutput) => void; /** * task beforeRun 在run方法之前执行 * * @param taskContext */ beforeRun?: (taskContext: HvigorTaskContext) => void | Promise<void>; /** * 增量输入输出 * * @param taskContext */ afterRun?: (taskContext: HvigorTaskContext) => void | Promise<void>; /** * Task执行逻辑,执行时调用此方法 * * @param taskContext */ run: (taskContext: HvigorTaskContext) => void | Promise<void>; /** * 当前Task依赖的Task列表 * 前置依赖的tasks, 先执行前置依赖,再执行此task */ dependencies?: (() => string[]) | string[]; /** * 后置依赖的tasks, 执行后置依赖前,必须先执行此task */ postDependencies?: (() => string[]) | string[]; }

我们主要需要实现run方法,这个是当执行到我们任务时任务的主要功能,并且声明任务处于任务链中的环节通过设置dependencies设置前置和后置依赖,下面是一个演示任务,作用于harmony工程中的module级工程,可以实现编译并且自动拷贝har包到sdk文件内

/** * 组件Har包打包导出脚本实现 */ import path from 'node:path'; import os from 'node:os'; import { HvigorTask, HvigorTaskContext, TaskInput, TaskOutput } from '@ohos/hvigor'; import fs from "fs-extra" export class ExampleTask implements HvigorTask { private harPath: string = "/build/default/outputs/default/"; constructor() { } name: string = "ExampleTask"; context?: any; run(taskContext: HvigorTaskContext) { console.log(taskContext.modulePath); function getHarInfo() { try { let res = fs.readJSONSync(path.join(taskContext.modulePath, "oh-package.json5")) return { "name": res.name, "version": res.version } } catch (e) { console.log(e); } } let harInfo = getHarInfo(); let source = path.join(taskContext.modulePath, this.harPath, harInfo!.name + ".har"); let type = ""; if (os.platform() === "win32") { type = taskContext.modulePath.replace("\\" + harInfo?.name, "") .substring(taskContext.modulePath.replace("\\" + harInfo?.name, "").lastIndexOf("\\")) } else { type = taskContext.modulePath.replace("/" + harInfo?.name, "") .substring(taskContext.modulePath.replace("/" + harInfo?.name, "").lastIndexOf("/")) } console.log("bundle", taskContext.modulePath.replace("/" + harInfo?.name, ""), "type", type); if (!fs.existsSync(path.join(taskContext.modulePath, "/sdk/", type))) { fs.mkdirSync(path.join(taskContext.modulePath, "/sdk/", type), { recursive: true }) } let dist = path.join(taskContext.modulePath, "/sdk/", harInfo!.name + "-" + harInfo?.version + ".har") console.log("开始拷贝输出文件", source, dist); fs.copyFileSync(source, dist) }; beforeRun(taskContext: HvigorTaskContext) { this.dependencies = ['default@PackageHar'] } dependencies = ['default@PackageHar'] }

2、将自定义任务注册到harmony工程中的module中并执行

在需要增加任务的module下hvigorfile.ts中增加任务注册
如下图所示:

import { harTasks } from '@ohos/hvigor-ohos-plugin'; import { ExampleTask } from "../plugin/index.ts" export function ExamplePlugin() { return { pluginId: "ExamplePlugin", apply(pluginContext) { pluginContext.registerTask(new ExampleTask()) } } } export default { system: harTasks, plugins: [ExamplePlugin()] };

注册一个任务名称为ExamplePlugin的任务,并且导出任务级别为harTasks等级,注册后可以通过命令hvigorw(windows为hvigorw.bat) --mode module -p product=default -p module=library@default ExampleTask 执行任务
执行成功后控制台显示

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 10:40:18

Monorepo 在前端工程化中的深度实践与演进

Monorepo 在前端工程化中的深度实践与演进 1. 什么是 Monorepo 1.1 核心定义 Monorepo&#xff08;单一代码仓库&#xff09;是一种项目代码管理架构模式&#xff0c;指将多个相关项目或包&#xff08;Package&#xff09;存储在同一个代码版本库&#xff08;Repository&#x…

作者头像 李华
网站建设 2026/4/16 10:40:41

模块十一.接口和多态

1.接口1.接口的介绍2.接口的使用1.定义接口public interface 接口名{}2.实现&#xff1a;public class 实现类名 implements 接口名{}3.使用&#xff1a;a.实现类实现接口b.重写接口中的抽象方法c.创建实现类对象&#xff08;接口不能直接调用new对象&#xff09;d.调用重写的方…

作者头像 李华
网站建设 2026/4/4 10:30:04

CV技术的应用现状和CNN模型识别图像的流程

CV&#xff08;计算机视觉&#xff09;技术借助深度学习等核心算法&#xff0c;搭配硬件算力的升级&#xff0c;已在工业、医疗、安防等多个领域实现规模化落地&#xff0c;成为推动各行业智能化转型的关键力量&#xff0c;以下是其主要应用现状的简述&#xff1a;工业制造&…

作者头像 李华
网站建设 2026/4/8 12:40:39

springboot基于vue的 小程序 百度云网盘资源搜索平台设计与实现_87h89z17

目录 已开发项目效果实现截图开发技术系统开发工具&#xff1a; 核心代码参考示例1.建立用户稀疏矩阵&#xff0c;用于用户相似度计算【相似度矩阵】2.计算目标用户与其他用户的相似度系统测试总结源码文档获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&am…

作者头像 李华
网站建设 2026/4/16 10:38:42

如何在 C# 中创建、读取和更新 Excel 文档

在日常开发中&#xff0c;C# 操作 Excel 文档是普遍且重要的需求。无论是数据导入导出、报表生成&#xff0c;还是数据分析&#xff0c;Excel 都扮演着不可或缺的角色。然而&#xff0c;手动处理大量数据不仅效率低下&#xff0c;还极易出错。传统的 C# 操作 Excel 的方式&…

作者头像 李华
网站建设 2026/4/16 1:02:58

Obsidian美化实战手册:从零打造个性化知识管理界面

Obsidian美化实战手册&#xff1a;从零打造个性化知识管理界面 【免费下载链接】awesome-obsidian &#x1f576;️ Awesome stuff for Obsidian 项目地址: https://gitcode.com/gh_mirrors/aw/awesome-obsidian 你是否曾经面对单调的Obsidian界面感到审美疲劳&#xff…

作者头像 李华