news 2026/6/24 1:49:26

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/6/22 23:09:05

利用 DeepSeek 提升工作效率

理解 DeepSeek 的核心功能介绍 DeepSeek 的基础能力&#xff0c;如文本生成、代码辅助、数据分析等对比与传统工具的差异&#xff0c;突出智能化与效率提升日常任务自动化邮件与文档撰写&#xff1a;快速生成初稿或模板会议纪要整理&#xff1a;从录音或笔记中提取关键信息数据…

作者头像 李华
网站建设 2026/6/23 2:17:16

Webhook.site终极选择指南:自部署与云端方案深度解析

Webhook.site终极选择指南&#xff1a;自部署与云端方案深度解析 【免费下载链接】webhook.site webhooksite/webhook.site: 是一个简单的 Webhook 接收和回调服务器&#xff0c;它可以接收 HTTP POST 请求并将其转发到指定的回调 URL。适合用于实现简单的 Webhook 接收和回调功…

作者头像 李华
网站建设 2026/6/23 17:12:22

PHPBrew自定义任务终极指南:扩展开发与实战技巧

PHPBrew自定义任务终极指南&#xff1a;扩展开发与实战技巧 【免费下载链接】agent-framework A framework for building, orchestrating and deploying AI agents and multi-agent workflows with support for Python and .NET. 项目地址: https://gitcode.com/GitHub_Trend…

作者头像 李华
网站建设 2026/6/23 19:46:22

如何优雅重构HP-Socket应用:Deno 2.0兼容性深度解析与迁移策略

如何优雅重构HP-Socket应用&#xff1a;Deno 2.0兼容性深度解析与迁移策略 【免费下载链接】HP-Socket High Performance TCP/UDP/HTTP Communication Component 项目地址: https://gitcode.com/gh_mirrors/hp/HP-Socket HP-Socket作为高性能网络通信框架&#xff0c;在…

作者头像 李华
网站建设 2026/6/23 19:48:47

老旧Mac升级终极指南:完整教程解锁macOS兼容新世界

老旧Mac升级终极指南&#xff1a;完整教程解锁macOS兼容新世界 【免费下载链接】OCLP-Mod A mod version for OCLP,with more interesting features. 项目地址: https://gitcode.com/gh_mirrors/oc/OCLP-Mod 还在为你的老旧Mac无法安装最新系统而烦恼吗&#xff1f;每次…

作者头像 李华