TypeScript CLI:自动化构建和部署脚本

>我想跟进我以前的有关打字稿cli的文章。我要继续进行以下操作:我计划实现构建命令以构建vite应用程序和deploy命令,以将应用程序部署到amazon s3和aws cloudfront。

zirkelc >为您的monorepo创建打字稿cli

克里斯·库克(chris cook

#typescript #javascript #webdev #编程

>我们将使用listr2作为任务跑步者来定义构建和部署应用所需的步骤。我们将使用execa运行vite和aws的cli命令。由于我们正在运行打字稿代码,因此我们可以使用程序化api而不是cli命令,但让我们保持简单!>

#!/usr/bin/env -S pnpm tsximport chalk from 'chalk';import { Command } from 'commander';import { Listr } from 'listr2';import { $ } from 'execa';interface Ctx {  command: 'build' | 'deploy';}const tasks = new Listr(  [    /**     * Build tasks     */    {      enabled: (ctx) => ctx.command === 'build' || ctx.command === 'deploy',      title: 'Build',      task: (ctx, task): Listr =>        task.newListr([          /**           * Runs `vite build`.           */          {            title: `Run ${chalk.magenta('vite build')}`,            task: async (ctx, task): Promise => {              const cmd = $({ all: true })`vite build`;              cmd.all.pipe(task.stdout());              await cmd;              task.output = `Build completed: ${chalk.dim('./dist')}`;            },            rendererOptions: { persistentOutput: true },          },        ]),    },    /**     * Deploy tasks     */    {      enabled: (ctx) => ctx.command === 'deploy',      title: 'Deploy',      task: (ctx, task): Listr =>        task.newListr([          /**           * Runs `aws s3 sync`.           */          {            title: `Run ${chalk.magenta('aws s3 sync')}`,            task: async (ctx, task): Promise => {              const build = './dist';              const bucket = 's3://my-bucket';              const cmd = $({ all: true })`aws s3 sync ${build} ${bucket} --delete`;              cmd.all.pipe(task.stdout());              await cmd;              task.output = `S3 sync completed: ${chalk.dim(bucket)}`;            },            rendererOptions: { persistentOutput: true },          },          /**           * Runs `aws cloudfront create-invalidation`.           */          {            title: `Run ${chalk.magenta('aws cloudfront create-invalidation')}`,            task: async (ctx, task): Promise => {              const distributionId = 'E1234567890ABC';              const cmd = $({ all: true })`aws cloudfront create-invalidation --distribution-id ${distributionId} --paths /* --no-cli-pager`;              cmd.all.pipe(task.stdout());              await cmd;              task.output = `CloudFront invalidation completed: ${chalk.dim(distributionId)}`;            },            rendererOptions: { persistentOutput: true },          },        ]),    },  ],  {    rendererOptions: {      collapseSubtasks: false,    },  },);const program = new Command()  .name('monorepo')  .description('CLI for Monorepo')  .version('1.0.0');program  .command('build')  .description('Build the monorepo')  .action(async () => {    await tasks.run({ command: 'build' });  });program  .command('deploy')  .description('Deploy the monorepo')  .action(async () => {    await tasks.run({ command: 'deploy' });  });await program.parseAsync(process.argv);

任务分为构建任务和部署任务。由于部署需要一个构建步骤,因此我们使用启用属性来有条件地启用基于cli命令构建或部署的任务。每个任务都执行相应的cli命令并将其输出输出到控制台。

>将此脚本保存为cli.ts,并使用pnpm tsx cli运行:

即构数智人 即构数智人

即构数智人是由即构科技推出的AI虚拟数字人视频创作平台,支持数字人形象定制、短视频创作、数字人直播等。

即构数智人 36 查看详情 即构数智人

asciicast

以上就是TypeScript CLI:自动化构建和部署脚本的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/372192.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月6日 08:14:48
下一篇 2025年11月6日 08:15:53

相关推荐

  • 使用 WebCodecs VideoDecoder 实现精确逐帧回退

    本文档旨在解决在使用 WebCodecs VideoDecoder 进行视频解码时,实现精确逐帧回退的问题。通过比较帧的时间戳与目标帧的时间戳,可以避免渲染中间帧,从而提高用户体验。本文将提供详细的解决方案和示例代码,帮助开发者实现精确的视频帧控制。 在使用 WebCodecs VideoDecod…

    2025年12月20日
    000
  • 使用 JavaScript 根据对象数组过滤对象数组

    本文介绍了如何使用 JavaScript 根据另一个对象数组中的条件,高效地过滤对象数组。通过将过滤器条件转换为约束条件,并使用 filter、every 和 some 方法,可以灵活地实现复杂的过滤逻辑,并提供示例代码进行演示。 对象数组过滤详解 在 JavaScript 开发中,经常会遇到需要根…

    2025年12月20日
    000
  • 基于多条件过滤对象数组的实用指南

    本文档旨在提供一种高效且通用的方法,用于根据多个筛选条件过滤对象数组。我们将探讨如何处理包含数组属性的对象,并根据用户选择的多个筛选条件,从原始数组中提取所需的数据子集。通过本文,你将学会如何灵活运用 JavaScript 的 filter、every 和 some 方法,构建强大的数据筛选功能。 …

    2025年12月20日
    000
  • 基于多条件过滤对象数组的 JavaScript 教程

    本文档旨在提供一种高效且灵活的方法,用于根据多个条件过滤 JavaScript 对象数组。我们将通过一个实际示例,演示如何利用 filter 和 every 等数组方法,结合动态属性访问,实现复杂的过滤逻辑。该方法可以处理多种过滤条件,并能适应不同数据结构。 在实际开发中,经常需要根据用户的选择或特…

    2025年12月20日
    000
  • 基于多条件筛选对象数组的实用指南

    本文旨在提供一种高效的方法,根据用户定义的多条件筛选规则,从对象数组中提取所需数据。通过解析筛选条件并结合数组的filter和some方法,实现灵活且强大的数据过滤功能。本文将提供详细的代码示例和解释,帮助开发者快速掌握该技术。 在实际开发中,我们经常需要根据用户的选择,从一个包含多个对象的数组中筛…

    2025年12月20日
    000
  • 使用 JavaScript 过滤对象数组:基于多条件筛选

    本文旨在提供一种高效且灵活的方法,用于根据用户定义的多条件筛选对象数组。我们将探讨如何利用 JavaScript 的数组方法,结合动态条件判断,实现对复杂数据集的精确过滤,并提供可复用的代码示例。 在实际开发中,经常需要根据用户的选择或某些条件,从一个对象数组中筛选出符合特定要求的元素。如果筛选条件…

    2025年12月20日
    000
  • 全局设置 Ext.Ajax 请求的额外参数

    本文介绍了在 ExtJS 7 应用中全局设置 Ext.Ajax 请求额外参数的方法。通过监听 beforerequest 事件,可以在每次 Ajax 请求发送前修改请求参数,从而实现全局添加额外参数的需求,避免修改大量的现有代码。 在 ExtJS 应用开发中,经常会遇到需要在所有 Ajax 请求中添…

    2025年12月20日
    000
  • Mongoose多数据库连接与模型使用指南

    本教程旨在解决Mongoose在使用mongoose.createConnection建立多数据库连接时,模型实例化遇到的常见错误。我们将详细讲解如何在特定连接上正确定义和注册模型,并演示如何通过该连接实例来创建和操作模型实例,确保数据能准确地保存到指定的数据库中,避免TypeError: conn…

    2025年12月20日
    000
  • Mongoose 多数据库连接与模型管理深度指南

    本教程详细阐述了在 Mongoose 中如何高效管理多个 MongoDB 数据库连接及其对应的模型。我们将深入探讨使用 mongoose.createConnection 建立独立连接的方法,以及如何正确地为每个连接定义、实例化和操作其专属模型,避免常见的模型构造函数错误,确保数据操作的准确性和隔离…

    2025年12月20日
    000
  • Mongoose多数据库连接与模型管理深度解析

    本教程深入探讨了Mongoose中如何高效管理多个数据库连接。我们将学习如何使用mongoose.createConnection建立独立的数据库连接,以及如何在这些特定连接上正确定义和实例化Mongoose模型,避免常见的TypeError: conn.Price is not a constru…

    2025年12月20日
    000
  • 使用JavaScript实现WhatsApp状态的程序化发布

    本教程将详细介绍如何利用JavaScript结合第三方API服务,实现WhatsApp状态的程序化自动发布。文章涵盖了API接口的选择、认证方式、请求参数的构建(包括文本和图片状态),并提供了具体的代码示例。请注意,此方法依赖于非官方API,使用时需自行承担风险,并确保API令牌的安全性。 概述与实…

    2025年12月20日
    000
  • Mongoose多数据库连接下的模型管理与实例化指南

    本文旨在解决Mongoose在使用mongoose.createConnection建立多数据库连接时,访问模型时遇到的TypeError: conn.Price is not a constructor错误。我们将深入探讨Mongoose模型与连接的工作原理,区分全局模型定义与特定连接模型定义,并…

    2025年12月20日
    000
  • JavaScript实现WhatsApp状态自动化发布教程

    本教程探讨如何利用JavaScript通过第三方服务网关实现WhatsApp状态的程序化发布。由于WhatsApp官方未提供直接的公共API,本文将指导您使用外部API服务进行认证、构建请求体,并发送包含文本或媒体内容的状态更新。请注意,此为非官方解决方案,使用时需谨慎评估风险。 1. 理解what…

    2025年12月20日
    000
  • 将外部 JavaScript 文件嵌入 HTML 的实用指南

    第一段引用上面的摘要: 本文介绍了一种将外部 JavaScript 文件嵌入到 HTML 文件中的方法,以便生成独立的 HTML 文件。通过使用 m4 宏处理器,我们可以轻松地将 JavaScript 代码直接嵌入到 标签中,从而简化开发流程并提高模块化程度。 使用 m4 宏处理器嵌入 JavaSc…

    2025年12月20日
    000
  • 将外部 JavaScript 文件嵌入 HTML 的教程

    本文介绍了一种将外部 JavaScript 文件嵌入到 HTML 文件中的方法,以便生成独立的 HTML 文件。通过使用 m4 宏处理器,可以轻松地将外部 JavaScript 文件的内容直接插入到 HTML 文件的 标签中,从而避免了对外部 JavaScript 文件的依赖,并简化了部署流程。 使…

    2025年12月20日
    000
  • Node.js中事件循环和资源释放的关系

    node.js 中避免内存泄漏需正确管理资源。1. 使用 try…finally 块确保异常情况下资源也能释放;2. 利用流自动管理资源,处理大数据更高效;3. 使用 async/await 和 using 语句(node.js 16+)简化异步资源管理;4. 及时清除不再需要的定时器,…

    2025年12月20日 好文分享
    000
  • js如何检测原型链的终点

    javascript中,原型链的终点是null,因为object.prototype的原型被设计为null,从而避免无限递归并为属性查找提供明确的终止条件;通过反复调用object.getprototypeof()方法可追溯原型链,直到返回null即停止,例如使用while循环遍历currentpr…

    2025年12月20日 好文分享
    000
  • javascript数组如何实现优先级队列

    使用数组实现优先级队列的核心原因是其内存连续性和索引计算的直观性,能通过数学公式直接定位父子节点,提升缓存命中率并简化操作;2. 优先级队列常见于任务调度、图算法(如dijkstra和prim)、事件模拟、霍夫曼编码和网络数据包处理等需按重要性排序的场景;3. 处理相同优先级元素时,标准堆不保证顺序…

    2025年12月20日 好文分享
    000
  • 实现多选框联动:智能维护依赖关系

    本教程探讨如何使用JavaScript和jQuery实现多选框的智能联动。当多个复选框共同控制一个目标复选框时,传统方法可能导致目标复选框过早取消选中。文章将展示一种优化方案,通过集中检查所有相关复选框的状态,确保目标复选框仅在所有关联项均未选中时才取消选中,从而实现更灵活、准确的用户交互逻辑。 问…

    2025年12月20日
    000
  • javascript如何实现数组分块处理

    数组分块处理能避免主线程长时间阻塞,保持页面响应性;1. 使用循环和slice是常见实现方式,通过chunkarray函数将数组按指定大小分割;2. processchunk函数模拟对每个小块的处理,并返回promise以支持异步操作;3. processarrayinchunks函数逐块处理并合并…

    2025年12月20日 好文分享
    000

发表回复

登录后才能评论
关注微信