详解Node.js如何开发命令行工具


Posted in Javascript onAugust 14, 2016

前言

Node 给前端开发带来了很大的改变,促进了前端开发的自动化,我们可以简化开发工作,然后利用各种工具包生成生产环境。如运行sass src/sass/main.scss dist/css/main.css即可编译 Sass 文件。

在实际的开发过程中,我们可能会有自己的特定需求,

那么我们得学会如何创建一个Node命令行工具。

hello world

老规矩第一个程序为hello world。在工程中新建bin目录,在该目录下创建名为helper的文件,具体内容如下:

#!/usr/bin/env node

console.log('hello world');

修改helper文件的权限:

$ chmod 755 ./bin/helper

执行helper文件,终端将会显示hello world

$ ./bin/helper
hello world

符号链接

接下来我们创建一个符号链接,在全局的node_modules目录之中,生成一个符号链接,指向模块的本地目录,使我们可以直接使用helper命令。

在工程的package.json文件中添加bin字段:

{
 "name": "helper",
 "bin": {
 "helper": "bin/helper"
 }
}

在当前工程目录下执行npm link命令,为当前模块创建一个符号链接:

$ npm link

/node_path/bin/helper -> /node_path/lib/node_modules/myModule/bin/helper
/node_path/lib/node_modules/myModule -> /Users/ipluser/myModule

现在我们可以直接使用helper命令:

$ helper
hello world

commander模块

为了更高效的编写命令行工具,我们使用TJ大神的commander模块。

$ npm install --save commander

helper文件内容修改为:

#!/usr/bin/env node

var program = require('commander');

program
 .version('1.0.0')
 .parse(process.argv);

执行helper -hhelper -V命令:

$ helper -h

 Usage: helper [options]

 Options:

 -h, --help  output usage information
 -V, --version output the version number

$ helper -V
1.0.0

commander模块提供-h, --help-V, --version两个内置命令。

创建命令

创建一个helper hello <author>的命令,当用户输入helper hello ipluser时,终端显示hello ipluser。修改helper文件内容:

#!/usr/bin/env node

var program = require('commander');

program
 .version('1.0.0')
 .usage('<command> [options]')
 .command('hello', 'hello the author') // 添加hello命令
 .parse(process.argv);

bin目录下新建helper-hello文件:

#!/usr/bin/env node

console.log('hello author');

执行helper hello命令:

$ helper hello ipluser
hello author

解析输入信息

我们希望author是由用户输入的,终端应该显示为hello ipluser。修改helper-hello文件内容,解析用户输入信息:

#!/usr/bin/env node

var program = require('commander');

program.parse(process.argv);

const author = program.args[0];

console.log('hello', author);

再执行helper hello ipluser命令:

$ helper hello ipluser
hello ipluser

哦耶,终于达到完成了,但作为程序员,这还远远不够。当用户没有输入author时,我们希望终端能提醒用户输入信息。

提示信息

helper-hello文件中添加提示信息:

#!/usr/bin/env node

var program = require('commander');

program.usage('<author>');

// 用户输入`helper hello -h`或`helper hello --helper`时,显示命令使用例子
program.on('--help', function() {
 console.log(' Examples:');
 console.log(' $ helper hello ipluser');
 console.log();
});

program.parse(process.argv);
(program.args.length < 1) && program.help(); // 用户没有输入信息时,调用`help`方法显示帮助信息

const author = program.args[0];

console.log('hello', author);

执行helper hellohelper hello -h命令,终端将会显示帮助信息:

$ helper hello

 Usage: helper-hello <author>

 Options:

 -h, --help output usage information

 Examples:
 $ helper hello ipluser

$ helper hello -h

 Usage: helper-hello <author>

 Options:

 -h, --help output usage information

 Examples:
 $ helper hello ipluser

总结

到此我们编写了一个helper命令行工具,并且具有helper hello <author>命令。刚兴趣的朋友们快快自己动手实践起来,只有自己做了才能算真正的学习了,希望本文对大家能有所帮助。

Javascript 相关文章推荐
jquery解析xml字符串简单示例
Apr 11 Javascript
JavaScript 定时器 SetTimeout之定时刷新窗口和关闭窗口(代码超简单)
Feb 26 Javascript
Vue.js每天必学之方法与事件处理器
Sep 06 Javascript
基于JavaScript实现瀑布流效果
Mar 29 Javascript
关于js中的鼠标事件总结
Jul 11 Javascript
利用JS做网页特效_大图轮播(实例讲解)
Aug 09 Javascript
JS实现的简单标签点击切换功能示例
Sep 21 Javascript
使用async-validator编写Form组件的方法
Jan 10 Javascript
js自定义trim函数实现删除两端空格功能
Feb 09 Javascript
JS面向对象编程基础篇(一) 对象和构造函数实例详解
Mar 03 Javascript
vue 使用async写数字动态加载效果案例
Jul 18 Javascript
jQuery实现图片切换效果
Oct 19 jQuery
javascript中的 object 和 function小结
Aug 14 #Javascript
JavaScript兼容浏览器FF/IE技巧
Aug 14 #Javascript
关于JavaScript限制字数的输入框的那些事
Aug 14 #Javascript
使用ajaxfileupload.js实现上传文件功能
Aug 13 #Javascript
几种二级联动案例(jQuery\Array\Ajax php)
Aug 13 #Javascript
漂亮! js实现颜色渐变效果
Aug 12 #Javascript
jQuery ztree实现动态树形多选菜单
Aug 12 #Javascript
You might like
PHP实现多进程并行操作的详解(可做守护进程)
2013/06/18 PHP
PHP获取数组中重复最多的元素的实现方法
2014/11/11 PHP
php图像处理类实例
2015/07/28 PHP
PHP常见过waf webshell以及最简单的检测方法
2019/05/21 PHP
JavaScript定义类和对象的方法
2014/11/26 Javascript
使用jquery动态加载js文件的方法
2014/12/24 Javascript
JavaScript中的getMilliseconds()方法使用详解
2015/06/10 Javascript
纯JavaScript代码实现移动设备绘图解锁
2015/10/16 Javascript
Vue.js每天必学之内部响应式原理探究
2016/09/07 Javascript
javascript经典特效分享 手风琴、轮播图、图片滑动
2016/09/14 Javascript
浅谈Angular中ngModel的$render
2016/10/24 Javascript
Vue.js表单控件实践
2016/10/27 Javascript
AngularJs上传前预览图片的实例代码
2017/01/20 Javascript
ionic中列表项增加和删除的实现方法
2017/01/22 Javascript
JavaScript中捕获与冒泡详解及实例
2017/02/03 Javascript
Vue模拟数据,实现路由进入商品详情页面的示例
2018/08/31 Javascript
3分钟了解vue数据劫持的原理实现
2019/05/01 Javascript
layui 动态设置checbox 选中状态的例子
2019/09/02 Javascript
使用vue制作滑动标签
2019/09/21 Javascript
在vue和element-ui的table中实现分页复选功能
2019/12/04 Javascript
在vue中使用el-tab-pane v-show/v-if无效的解决
2020/08/03 Javascript
Python利用pyHook实现监听用户鼠标与键盘事件
2014/08/21 Python
python任务调度实例分析
2015/05/19 Python
python 性能优化方法小结
2017/03/31 Python
详解Python使用tensorflow入门指南
2018/02/09 Python
python之从文件读取数据到list的实例讲解
2018/04/19 Python
Windows 64位下python3安装nltk模块
2018/09/19 Python
使用python判断jpeg图片的完整性实例
2019/06/10 Python
PyQt5使用QTimer实现电子时钟
2019/07/29 Python
python 如何上传包到pypi
2020/12/24 Python
房产销售经理职责
2013/12/20 职场文书
装修设计师求职信
2014/02/26 职场文书
大学学雷锋活动总结
2014/06/26 职场文书
归元寺导游词
2015/02/06 职场文书
医院病假条范文
2015/08/17 职场文书
从贫穷到富有,是知识技能和学习力的差别
2019/08/20 职场文书