入门commander

overview

官网写的readme太差了,连一个像样的demo都没有。我看了几天readme也没学会。后来仍是去看源码本身揣摸出来的。是tj太nb了,让我这个小白的看不懂他的的文章,仍是写不清楚本身的库能干什么、怎么干。下面是我写的demo。方便像我这样的小白入门。若你能看懂tj写的readme。关了这个页面吧。node

init project

mkdir projectCommand
cd projectCommand
lerna init
lerna create testCommand
lerna add commander

defined

修改./projectCommand/packages/testCommand/package.jsonnpm

{
    ...
    "bin": {
        "demo": "./bin/index.js"
    }
}

init cli

在中建立./projectCommand/packages/testCommand/bin/index.js。编辑内容以下:json

#!/usr/bin/env node

// 快速引入Commander的实例
const program = require('commander')
// 定义选项
program
    .option('-d, --debug', 'output extra debugging')
    .option('-s, --small', 'small pizza size')
// 解析选项,即:执行选项
program.parse(process.argv)
    // process.argv 会获取命令行的数据,返回类型是数组。
// 根据选项及其值,执行相应逻辑。
if (program.debug) console.log(program.opts())
if (program.small) console.log('- small pizza size')

该文件的处理逻辑:根据选项执行相应输出。数组

usage

在本包中使用命令

./projectCommand/packages/testCommand下执行npm link
再执行demo -d,则输出:{ debug: true, small: undefined }
再执行demo -s,则输出:- small pizza size
若获得相应输出,则验证cli运行正确。学习

在其余包中使用命令

建立一个其余包
./projectCommand/中执行ui

lerna create useCommand
lerna add testCommand
cd packages/testCommand
npm unlink               // 取消全局软连接该包
demo -d                  // 验证是否取消成功
// => zsh: command not found: demo

编辑./projectCommand/packages/useCommand/package.json命令行

{
    ...
    "script": {
        ...
        "useDemo": "demo -d"
    }
}

./projectCommand/packages/useCommand/下执行debug

npm run useDemo
// => { debug: true, small: undefined }

若获得相应输出,则验证cli运行正确。code

后记

记得在./projectCommand/packages/testCommand下执行npm unlink
删除projectCommand项目。ip

为何使用lerna建立项目

我已经学习了lerna。不用也是浪费。

package.json中的bin字段

它是定义命令的地方。本地中定义的命令叫demo。读者也能够叫别的名字。也能够定义多个命令。
定义命令在package.json中。使用命令在终端中。执行命令时会执行package.json中bin字段对应的文件。

命令对应的文件

#!/usr/bin/env node是标明当前文件是可执行文件。使用node解析当前文件。可执行文件的第一行必须是它。
请使用commonjs规范编辑该文件。

使用命令

如果全局安装该包则全局能够使用该包的命令。
如果局部安装该包则局部能够使用该包的命令。


by stone

相关文章
相关标签/搜索