当前位置: 首页 > 文档资料 > San CLI 中文文档 >

Command 插件

优质
小牛编辑
129浏览
2023-12-01

在日常开发中,我们可能需要扩展团队的 CLI 命令,比如给san命令添加一个san deploy命令,用于将代码上传到对应开发机上进行联调,这时候可以直接添加 San CLI 的 Command 插件来实现。

San CLI 的脚手架命令就是通过 Command 插件来实现的,详细代码可以参考san-cli-init对应的代码。

San CLI 的命令行解析是使用的yargs实现的,Command 插件需要遵循 yargs command module 规范,即按照下面的写法:

// 假设我们要给 san 添加一个 your_command_name
exports.command = 'your_command_name [your_option]';
// 这是命令的描述,or exports.desc
exports.describe = 'command description';
// 这是命令的别名,即 san alias_cmd === san your_command_name
exports.aliases = ['alias_cmd'];
// 这是命令的 flag 配置
exports.builder = {
    option1: {
        default: true,
        type: 'boolean'
    }
};
// builder 还支持函数写法,具体参见:
// 1. https://github.com/yargs/yargs/blob/master/docs/api.md#positionalkey-opt
// 2. https://github.com/yargs/yargs/blob/master/docs/api.md#commandmodule
// 执行命令的 handler,得到 yargs 解析后的 argv 对象
exports.handler = argv => {
    console.log(`setting ${argv.key} to ${argv.value}`);
};

Command 插件配置

将 Command 插件扩展到自己的 San CLI 中有两种方式:预设文件和package.json两种方式。

注意: 预设文件是放到电脑的 home 目录的,而且是全局的,所以个人配置的预设只是自己本人的,而不会影响到团队/项目;如果 Command 放到package.json,那么可以在这里执行 San CLI 命令,则会被执行。

1. 预设文件

Command 插件可以通过配置预设文件.sanrccommands字段,给 CLI 添加自定义 Command,这里添加的 Command 可以通过san your_command_name [options]方式使用。

2. package.json

Command 插件在package.json的配置也有两种方式:依赖和san配置。

  1. 如果遵循san-cli-command-xxx的命名方式,并且把依赖(dependencies, devDependencies)添加到项目的package.json那么在该项目中执行对应的 Command 就可以被执行;
  2. package.json中添加san.commands数组,添加自己的 Command 插件路径。

Command 插件举例

下面以给 San CLI 扩展一个hello的命令为例,介绍下具体的代码用法和编写。

首先创建一个 js 文件,内容如下:

// filename san-command.js
exports.command = 'hello';
exports.builder = {
    name: {
        type: 'string'
    }
};
exports.desc = 'San Command Plugin Demo';
exports.handler = argv => {
    console.log(`hello, ${argv.name}`);
};

然后在package.json中添加配置:

// package.json
{
    "name": "demo",
    //下面是扩展配置
    "san": {
        "commands": ["san-command.js"]
    }
}

这时候执行san hello --name demo就可以看到对应结果。

在 San CLI 的项目代码中,san-cli-init 是 Command 插件,可以查看源码实现。