# 安装

npm i commander
1

# 基本使用示例

主要展示了

  • 配置名称
  • 配置提示信息
  • 配置 option
  • 配置 option 的参数
  • 获取配置 option 参数
#!/usr/bin/env node

// // dev-log >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
console.log(`[Dev_Log][${"执行cli_sest"}_]_>>>`);

const commander = require("commander");
const pkg = require("../package.json");

// 创建commander的单个实例
const program = new commander.Command();

program
  .name(Object.keys(pkg.bin)[0]) // 命令名称
  .usage("<command> [options]") // 提示
  .version(pkg.version) // 版本
  .option("-d, --debug", "是否开启调试模式", false) // 选项 描述 默认值
  .option("-e, --envName <envName>", "获取环境变量名称") // 选项 <参数> 描述
  .parse(process.argv); // 输入参数options&paardm解析

// dev-log >>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>>
/** program._optionValues 或者 program.opts() 可以打印当前所有的 option 对象中的值 */
console.log(`[Dev_Log][${"program"}_]_>>>`, program._optionValues);
console.log(`[Dev_Log][${"program"}_]_>>>`, program.opts());

/** 打印帮助信息 */
program.outputHelp();
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26

# 命令注册

有两种方式

  • command
  • addCommand
#!/usr/bin/env node

const commander = require("commander");
const pkg = require("../package.json");

/**
 * 创建commander的单个实例
 * */
const program = new commander.Command();

/**
 * 执行
 * */
program
  .name(Object.keys(pkg.bin)[0]) // 命令名称
  .usage("<command> [options]") // 提示
  .version(pkg.version) // 版本
  .option("-d, --debug", "是否开启调试模式", false) // 选项 描述 默认值
  .option("-e, --envName <envName>", "获取环境变量名称"); // 选项 <参数> 描述

/**
 * command 注册命令 (方式一)
 * */
program
  .command("clone <source> [destination]") // <>必填、 []选填  // usage:cli_test clone sUrl dUrl
  .description("clone a repository into a newly created directory")
  .option("-f, --force", "是否强制克隆") // usage:cli_test clone sUrl dUrl -f
  .action((source, destination, commandOpt) => {
    console.log("clone command called", {
      source,
      destination,
      commandOpt,
    });
  });

/**
 * addCommand 注册命令&注册子命令 (方式二)
 *  */
const service = new commander.Command("service");

service
  .command("start [port]") // usage:cli_test service start 999
  .description("start service at [port]")
  .action((port) => {
    console.log("service start called", port);
  });

service
  .command("stop") // usage:cli_test service stop
  .description("stop service")
  .action((port) => {
    console.log("stop service");
  });

program.addCommand(service);

/**
 * 拼接命令用于执行其他库的命令
 */
// usage:[cli_test n list | cli_test i list ] equal [npm list]
// program
//   .command("n [name]", "n package", {
//     executableFile: "npm", // 指定要执行的命令别名
//     isDefault: true, // 忽略 program.arguments 检测
//     hidden: true, // 隐藏在帮助信息中command的打印显示(内部调试命令可设置)
//   })
//   .alias("i");

/**
 * 匹配所有输入的命令并检测
 */
// program
//   .arguments("<command> [options]")
//   .description(" parsed options and the command object itself", {
//     cmd: "command to run",
//     options: "options for command",
//   })
//   .action(function (command, options) {
//     console.log("command", options);
//   });

/**
 * 传入命令行的参数
 * */
program.parse(process.argv); // 输入参数options&paardm解析

/**
 * dev-log
 * */
// // program._optionValues 或者 program.opts() 可以打印当前所有的 option 对象中的值
// console.log(`[Dev_Log][${"program"}_]_>>>`, program);
// console.log(`[Dev_Log][${"program"}_]_>>>`, program._optionValues);
// console.log(`[Dev_Log][${"program"}_]_>>>`, program.opts());

// // 打印帮助信息
// program.outputHelp()
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96