news 2026/2/16 17:00:36

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/2/9 5:59:13

流量都去哪儿了?拯救APP月活,用FinClip轻松引入第三方生态

数据显示&#xff0c;超过80%的App在用户下载后30天内被遗忘。而企业又苦恼于App用户留存难&#xff0c;获客成本越来越高。 企业App可能一个月只被用户打开一两次&#xff0c;而用户每天在微信、支付宝里要用几十个服务。 为什么&#xff1f; 因为App提供的服务太单一&#xf…

作者头像 李华
网站建设 2026/2/7 3:36:24

终极指南:如何用Avalonia XPF实现WPF应用的革命性跨平台迁移

还在为WPF应用只能在Windows上运行而错失macOS和Linux市场机会吗&#xff1f;还在为每个平台重写UI代码而耗费大量开发资源吗&#xff1f;Avalonia XPF为您提供了完美的跨平台WPF解决方案&#xff0c;让现有的WPF应用程序能够在三大主流操作系统上运行&#xff0c;几乎无需代码…

作者头像 李华
网站建设 2026/2/13 0:22:04

企业级GitLab数据备份新方案:MinIO替代S3实战指南

企业级GitLab数据备份新方案&#xff1a;MinIO替代S3实战指南 【免费下载链接】docker-gitlab Dockerized GitLab 项目地址: https://gitcode.com/gh_mirrors/do/docker-gitlab 随着企业自建GitLab的普及&#xff0c;数据备份存储成本高、扩展性不足的问题日益凸显。传统…

作者头像 李华
网站建设 2026/2/13 15:29:40

Copyparty文件服务器:从零到精通的配置艺术

【免费下载链接】copyparty Portable file server with accelerated resumable uploads, dedup, WebDAV, FTP, TFTP, zeroconf, media indexer, thumbnails all in one file, no deps 项目地址: https://gitcode.com/GitHub_Trending/co/copyparty 你是否曾经为文件共享而…

作者头像 李华
网站建设 2026/2/8 22:08:54

Spring Boot与MySQL交互

Spring Boot与MySQL交互的核心步骤 配置MySQL依赖与数据源 在pom.xml中添加依赖&#xff1a; <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId> </dependency> <depend…

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

Spring Boot与mysql交互的注意事项

数据库连接配置 在application.properties或application.yml中正确配置MySQL连接参数&#xff0c;包括URL、用户名、密码及驱动类。URL需指定时区&#xff08;如serverTimezoneUTC&#xff09;&#xff0c;避免时区不一致导致的查询异常。 spring.datasource.urljdbc:mysql://l…

作者头像 李华