如何开发一个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 服务

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

相关推荐
测试19981 小时前
2026最新软件测试面试八股文【附文档】
自动化测试·软件测试·python·测试工具·面试·职场和发展·测试用例
幺风3 小时前
Claude Code 源码分析 — Tool/MCP/Skill 可扩展工具系统
前端·javascript·ai编程
ID_180079054733 小时前
淘宝 API 上货 / 商品搬家 业务场景实现 + JSON 返回示例
前端·javascript·json
M ? A3 小时前
Vue 动态组件在 React 中,VuReact 会如何实现?
前端·javascript·vue.js·经验分享·react.js·面试·vureact
竹林8185 小时前
RainbowKit快速集成多链钱包连接,我如何从“连不上”到“丝滑切换”
前端·javascript
不会敲代码15 小时前
手写一个「迷你 Cursor」:从零构建 AI 编程助手(LangChain + Tool Calling 实战)
langchain·node.js·cursor
No8g攻城狮5 小时前
【前端】Vue 中 const、var、let 的区别
前端·javascript·vue.js
fishmemory7sec6 小时前
Vue大屏自适应容器组件:v-scale-screen
前端·javascript·vue.js
饺子不吃醋6 小时前
Promise原理、手写与 async、await
前端·javascript
糯米团子7497 小时前
react速通-2
前端·react.js·前端框架