详解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的一句代码实现表格的简单筛选
Jul 26 Javascript
jquery struts 验证唯一标识(公用方法)
Mar 27 Javascript
22点关于jquery性能优化的建议
May 28 Javascript
JavaScript的作用域和块级作用域概念理解
Sep 21 Javascript
jquery实现表格本地排序的方法
Mar 11 Javascript
jQuery代码实现对话框右上角菜单带关闭×
May 03 Javascript
jQuery+ajax+asp.net获取Json值的方法
Jun 08 Javascript
简单三步实现报表页面集成天气
Dec 15 Javascript
js中常用的Math方法总结
Jan 12 Javascript
JS中利用localStorage防止页面动态添加数据刷新后数据丢失
Mar 10 Javascript
openLayer4实现动态改变标注图标
Aug 17 Javascript
JavaScript封装单向链表的示例代码
Sep 17 Javascript
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验证手机号码(支持归属地查询及编码为UTF8)
2013/02/01 PHP
怎样使用php与jquery设置和读取cookies
2013/08/08 PHP
PHP缓冲区用法总结
2016/02/14 PHP
PHP文件系统管理(实例讲解)
2017/09/19 PHP
一些实用的jQuery代码片段收集
2011/07/12 Javascript
js Array操作的最简短最容易理解方法
2013/12/09 Javascript
javascript动态向网页中添加表格实现代码
2014/02/19 Javascript
浅析基于WEB前端页面的页面内容搜索的实现思路
2014/06/10 Javascript
confirm的用法示例用于按钮操作时确定是否执行
2014/06/19 Javascript
node.js中的events.emitter.removeListener方法使用说明
2014/12/10 Javascript
JQuery工具函数汇总
2015/06/15 Javascript
JS实现三级折叠菜单特效,其它级可自动收缩
2015/08/06 Javascript
基于Bootstrap使用jQuery实现输入框组input-group的添加与删除
2016/05/03 Javascript
Vue 2.5 Level E 发布了: 新功能特性一览
2017/10/24 Javascript
Vue官网todoMVC示例代码
2018/01/29 Javascript
jQuery实现的隔行变色功能【案例】
2019/02/18 jQuery
vue项目在线上服务器访问失败原因分析
2020/08/14 Javascript
构建一个JavaScript插件系统
2020/10/20 Javascript
[43:33]EG vs Spirit Supermajor 败者组 BO3 第一场 6.4
2018/06/05 DOTA
[03:43]TI9战队采访——PSG.LGD
2019/08/22 DOTA
Python爬虫实现百度图片自动下载
2018/02/04 Python
python利用Tesseract识别验证码的方法示例
2019/01/21 Python
python使用wxpy轻松实现微信防撤回的方法
2019/02/21 Python
python assert的用处示例详解
2019/04/01 Python
Python_查看sqlite3表结构,查询语句的示例代码
2019/07/17 Python
Sisley法国希思黎中国官网:享誉全球的奢华植物美容品牌
2019/06/30 全球购物
班主任工作经验材料
2014/02/02 职场文书
清正廉洁演讲稿
2014/05/22 职场文书
学校地质灾害防治方案
2014/06/10 职场文书
会计电算化专业求职信
2014/06/10 职场文书
机关作风建设工作总结
2014/10/23 职场文书
事业单位年度考核个人总结
2015/02/12 职场文书
2015年万圣节活动总结
2015/03/24 职场文书
实习推荐信格式模板
2015/03/27 职场文书
投资公司董事长岗位职责
2015/04/16 职场文书
反邪教教育心得体会
2016/01/15 职场文书