详解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 相关文章推荐
JS 去前后空格大全(IE9亲测)
Jul 15 Javascript
JavaScript中的关键字&quot;VAR&quot;使用详解 分享
Jul 31 Javascript
jquery prop的使用介绍及与attr的区别
Dec 19 Javascript
JavaScript实现给定时间相加天数的方法
Jan 25 Javascript
获取url中用&amp;隔开的参数实例(分享)
May 28 Javascript
解决VUEX刷新的时候出现数据消失
Jul 03 Javascript
详解SPA中前端路由基本原理与实现方式
Sep 12 Javascript
浅谈目前可以使用ES10的5个新特性
Jun 25 Javascript
浅析Angular 实现一个repeat指令的方法
Jul 21 Javascript
微信小程序拼接图片链接无底洞深入探究
Sep 03 Javascript
新手入门js闭包学习过程解析
Oct 08 Javascript
js+canvas实现纸牌游戏
Mar 16 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与C#的值类型指向区别的详解
2013/05/21 PHP
PHP合并数组+号和array_merge的区别
2015/06/25 PHP
实例讲解通过​PHP创建数据库
2019/01/20 PHP
php字符串截取函数mb_substr用法实例分析
2019/06/25 PHP
javascript new 需不需要继续使用
2009/07/02 Javascript
Javascript学习笔记8 用JSON做原型
2010/01/11 Javascript
jQuery 打造动态渐变按钮 详细图文教程
2010/04/25 Javascript
解析URI与URL之间的区别与联系
2013/11/22 Javascript
jquery实现具有嵌套功能的选项卡
2016/02/12 Javascript
深入理解JavaScript中的对象复制(Object Clone)
2016/05/18 Javascript
js友好的时间返回函数
2016/08/24 Javascript
用Nodejs搭建服务器访问html、css、JS等静态资源文件
2017/04/28 NodeJs
20170918 前端开发周报之JS前端开发必看
2017/09/18 Javascript
从源码看angular/material2 中 dialog模块的实现方法
2017/10/18 Javascript
vue watch监听对象及对应值的变化详解
2018/02/24 Javascript
JS实现的合并多个数组去重算法示例
2018/04/11 Javascript
JavaScript实现原型封装轮播图
2020/12/27 Javascript
[05:34]2014DOTA2国际邀请赛中国区预选赛精彩TOPPLAY第二弹
2014/06/25 DOTA
[14:03]2017DOTA2亚洲邀请赛开幕式:12神兵演绎水墨中华
2017/04/01 DOTA
深入理解python函数递归和生成器
2016/06/06 Python
Python 中包/模块的 `import` 操作代码
2019/04/22 Python
Django之choices选项和富文本编辑器的使用详解
2020/04/01 Python
如何基于pandas读取csv后合并两个股票
2020/09/25 Python
详解Django ORM引发的数据库N+1性能问题
2020/10/12 Python
css3背景_动力节点Java学院整理
2017/07/11 HTML / CSS
基础的CSS3弹性盒Flexbox布局使用实例
2016/04/08 HTML / CSS
财政局长自荐信范文
2013/12/22 职场文书
国贸专业自荐信范文
2014/03/02 职场文书
2014三八妇女节活动总结范文四篇
2014/03/09 职场文书
星级党支部申报材料
2014/05/31 职场文书
2014年小学生教师节演讲稿范文
2014/09/10 职场文书
无犯罪记录证明范本
2014/09/15 职场文书
员工工作自我评价
2014/09/26 职场文书
2016教师廉洁从教心得体会
2016/01/13 职场文书
数据库连接池
2021/04/06 MySQL
python 中yaml文件用法大全
2021/07/04 Python