如何开发一个CLI工具?

一、CLI 工具本质是什么?

一句话:

👉 一个通过命令行触发的 Node 程序 + 参数解析 + 输出结果

比如:

复制代码
my-cli create project-name
my-cli build
my-cli deploy --env=prod

二、技术选型(推荐组合)

基于你现在的技术背景,推荐:

核心

  • Node.js(必须)

  • npm / pnpm(发布)

常用库

  • 参数解析:commander(最主流)

  • 交互式命令:inquirer

  • 终端美化:chalk

  • 加载动画:ora

  • 执行 shell:execa


三、最小可用 CLI(一步一步做)

1. 初始化项目

复制代码
mkdir my-cli
cd my-cli
npm init -y

2. 声明 CLI 入口

package.json 里加:

复制代码
{
  "name": "my-cli",
  "bin": {
    "my-cli": "./bin/index.js"
  }
}

👉 这一步非常关键:

以后你可以直接在终端输入 my-cli


3. 创建入口文件

复制代码
mkdir bin
touch bin/index.js

写入:

复制代码
#!/usr/bin/env node

console.log('Hello CLI');

加权限:

复制代码
chmod +x bin/index.js

4. 本地测试 CLI

复制代码
npm link

然后运行:

复制代码
my-cli

四、加入命令解析(核心能力)

用 commander:

复制代码
npm install commander

#!/usr/bin/env node
const { Command } = require('commander');

const program = new Command();

program
  .name('my-cli')
  .description('一个示例 CLI 工具')
  .version('1.0.0');

program
  .command('create <name>')
  .description('创建项目')
  .option('-t, --template <type>', '模板类型')
  .action((name, options) => {
    console.log('项目名:', name);
    console.log('模板:', options.template);
  });

program.parse();

运行:

复制代码
my-cli create demo -t react

五、加入交互(更像真实工具)

复制代码
npm install inquirer

const inquirer = require('inquirer');

async function ask() {
  const answers = await inquirer.prompt([
    {
      type: 'input',
      name: 'projectName',
      message: '项目名称?'
    }
  ]);

  console.log(answers);
}

ask();

六、真实 CLI 会做什么?

你可以做这些(很实用):

1️⃣ 项目脚手架(最常见)

类似:

  • create-react-app

  • vite

功能:

  • 拉模板

  • 自动安装依赖

  • 初始化 git

👉 核心:

复制代码
const execa = require('execa');

await execa('git', ['clone', repo]);

2️⃣ 自动化工具

比如:

  • 一键部署

  • 自动打包

  • 发布 npm


3️⃣ 内部效率工具(你现在项目很适合)

比如:

  • 自动生成 API 文件

  • 自动生成表格配置

  • 自动生成 React 页面模板


七、发布到 npm(让别人也能用)

复制代码
npm login
npm publish

别人就可以:

复制代码
npm install -g my-cli
my-cli create demo

八、进阶能力(重点)

你可以逐步升级 CLI:

✅ 1. 下载远程模板

复制代码
npm install download-git-repo

✅ 2. 动态配置模板

  • handlebars / ejs

✅ 3. 多命令拆分结构

复制代码
commands/
  create.js
  build.js
  deploy.js

✅ 4. 支持 TypeScript

直接用 TS 写 CLI(强烈推荐)


九、一个真实 CLI 结构(推荐你照这个写)

复制代码
my-cli/
├── bin/
│   └── index.js
├── commands/
│   ├── create.js
│   └── build.js
├── utils/
│   └── log.js
├── package.json

十、给你一个练手项目(很适合你)

你可以做一个:

👉 "性能平台 CLI 工具"

结合你现在的项目:

功能:

  • perf create page → 自动生成页面模板

  • perf create api → 自动生成接口文件

  • perf report → 自动导出 Excel / PDF

  • perf mock → 启动 mock 服务

这会直接提升你工作效率,也能写进简历(非常加分)。

相关推荐
kyriewen1 天前
别再 console.log 了:5 个 Chrome DevTools 调试技巧,用过就回不去了
前端·javascript·面试
To_OC1 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
GuWenyue1 天前
排序效率低?5分钟吃透快速排序,性能飙升至O(nlogn)
前端·javascript·面试
叁两1 天前
前端转型AI Agent该如何学习?(前置篇)
前端·人工智能·node.js
何时梦醒1 天前
深入理解递归与快速排序 —— 从基础入门到手写实现
前端·javascript
bonechips1 天前
LLM 的无状态:从 HTTP 协议到对话上下文工程
前端·javascript
胡志辉1 天前
从 prototype 到 V8,看懂 JavaScript 原型链
前端·javascript
ping某1 天前
专栏-null 和 undefined 到底是什么?
前端·javascript·后端
swipe1 天前
从 0 到 1 理解 React 虚拟列表:定高、不定高与 Canvas 版本完整拆解
前端·javascript·面试
铁皮饭盒1 天前
Bun执行python代码
前端·javascript·后端