全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

利用node.js制作命令行工具方法教程(一)

前言

之前使用过一些全局安装的NPM包,安装完之后,可以通过其提供的命令,完成一些任务。比如Fis3,可以通过fis3 server start 开启fis的静态文件服务,通过fis3 release开启文件编译与发布;还有vue-cli,可以通过vue init webpack my-project来初始化vue+webpack的项目基础配置。最近有一个需求,需要写一个类似vue-cli的NPM包,通过命令行操作实现项目初始配置,所以就查看了相关资料,学习了一下如何使用node来生成自己的命令。

编写命令行

命令的目标:在当前目录下开启一个静态文件服务,端口号为8085

1.创建目录

构成命令的基础是需要一个命令文件web.js和package.json配置文件,执行以下命令:

$ mkdir node-commander #创建一个文件夹

$ cd node-commander && mkdir bin

$ npm init #初始化package.json文件<br>$ cd bin && touch web.js #创建命令文件

2.命令文件 

#!/usr/bin/env node

 

var express = require('express');

var path = process.cwd();

 

function run(argv) {

 if (argv[0] === '-v' || argv[0] === '--version') {

 console.log('version is 1.0.0');

 }

 else if (argv[0] === '-h' || argv[0] === '--help') {

 console.log('usage:\n');

 console.log('-v --version [show version]')

 }

 else if (argv[0] === '-s' || argv[0] === '--start') {

 var app = new express();

 app.use('/static', express.static(path));

 app.listen(8085, function () {

 console.log('server start at port 8085');

 });

 }

}

 

run(process.argv.slice(2)); 

文件的头部务必加入#!/usr/bin/env node这行代码,这里表示使用node作为脚本的解释程序,node的路径通过env来查找,可以避免node安装路径不一带来的问题。

其中process为node进程中的全局变量,process.argv为一数组,数组内存储着命令行的各个部分,argv[0]为node的安装路径,argv[1]为主模块文件路劲,剩下为子命令或参数,如下:

node ./bin/web.js a b c

# process.argv的值为[ '/usr/local/bin/node', '/PATH/web.js', 'a', 'b', 'c' ]

3.命令配置

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

"bin": {

 "web": "./bin/web.js"

 },  

bin字段的作用:当安装npm包时,npm将添加一条命令/usr/local/bin/web,web命令软连接到web.js文件。

调试命令行

(1)采用install方法

进入npm包目录下,执行全局install,根据package.json中bin的配置,为全局命令创建软连。

# sudo npm install . -g
/usr/local/bin/web -> /usr/local/lib/node_modules/cli-demo/bin/web.js

/usr/local/lib

`-- cli-demo@1.0.0
...

查看web命令

# which web 

/usr/local/bin/web  

执行web命令

# web --start

server start at port 8085

(2)采用npm link方法

npm link方法创建了两个软连,命令与命令文件的软连,全局包与实际包文件的软连。

# sudo npm link

 

/usr/local/bin/web -> /usr/local/lib/node_modules/cli-demo/bin/web.js

/usr/local/lib/node_modules/cli-demo -> /Users/baidu/hwm/home/demos/node/node-commander  

接下来可以按照方法(1)进行操作了。

发布命令包

通过npm publish进行发布,前提是有npm帐号。如何操作可以查看npm 官方文档。

本文是通过原生node.js来开发命令工具,而vue-cli是采用commander.js来简化命令工具开发,关于commander.js的使用方法,将在下一篇文章中介绍。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对的支持。


# nodejs命令行工具  # nodejs  # 命令行  # nodejs开发命令行工具  # Node.js 使用命令行工具检查更新  # 详解Node.js如何开发命令行工具  # 浅谈node.js 命令行工具(cli)  # node通过npm写一个cli命令行工具  # 使用node打造自己的命令行工具方法教程  # 详解用Node.js写一个简单的命令行工具  # 详解Node.js 命令行程序开发教程  # 手把手教你如何使用nodejs编写cli命令行  # 如何制作一个Node命令行图像识别工具  # 命令行批量截图Node脚本示例代码  # 可以通过  # 自己的  # 看了  # 目录下  # 是有  # 将在  # 帐号  # 作了  # 下一  # 相关资料  # 这篇文章  # 谢谢大家  # 使用过  # 连接到  # 如何使用  # 创建一个  # 配置文件  # 值为  # 可以查看 


相关文章: 魔毅自助建站系统:模板定制与SEO优化一键生成指南  建站主机与虚拟主机有何区别?如何选择最优方案?  微课制作网站有哪些,微课网怎么进?  完全自定义免费建站平台:主题模板在线生成一站式服务  外汇网站制作流程,如何在工商银行网站上做外汇买卖?  如何通过网站建站时间优化SEO与用户体验?  如何在万网主机上快速搭建网站?  香港服务器网站卡顿?如何解决网络延迟与负载问题?  如何选择高效便捷的WAP商城建站系统?  c# await 一个已经完成的Task会发生什么  简易网站制作视频教程,使用记事本编写一个简单的网页html文件?  定制建站平台哪家好?企业官网搭建与快速建站方案推荐  网站广告牌制作方法,街上的广告牌,横幅,用PS还是其他软件做的?  建站之星后台密码遗忘?如何快速找回?  如何快速搭建高效香港服务器网站?  如何通过IIS搭建网站并配置访问权限?  如何通过VPS搭建网站快速盈利?  如何在Windows 2008云服务器安全搭建网站?  胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?  打鱼网站制作软件,波克捕鱼官方号怎么注册?  建站之星伪静态规则如何正确配置?  建站之星24小时客服电话如何获取?  c# Task.ConfigureAwait(true) 在什么场景下是必须的  网站专业制作公司有哪些,做一个公司网站要多少钱?  如何用狗爹虚拟主机快速搭建网站?  杭州银行网站设计制作流程,杭州银行怎么开通认证方式?  建站之星安全性能如何?防护体系能否抵御黑客入侵?  ,想在网上投简历,哪几个网站比较好?  如何在建站宝盒中设置产品搜索功能?  如何构建满足综合性能需求的优质建站方案?  北京制作网站的公司排名,北京三快科技有限公司是做什么?北京三快科技?  上海网站制作开发公司,上海买房比较好的网站有哪些?  如何在Ubuntu系统下快速搭建WordPress个人网站?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  如何在七牛云存储上搭建网站并设置自定义域名?  c++怎么使用类型萃取type_traits_c++ 模板元编程类型判断【方法】  专业网站建设制作报价,网页设计制作要考什么证?  如何在Golang中使用encoding/gob序列化对象_存储和传输数据  青岛网站建设如何选择本地服务器?  魔方云NAT建站如何实现端口转发?  常州自助建站费用包含哪些项目?  如何零基础在云服务器搭建WordPress站点?  如何通过老薛主机一键快速建站?  如何快速搭建支持数据库操作的智能建站平台?  如何用腾讯建站主机快速创建免费网站?  百度网页制作网站有哪些,谁能告诉我百度网站是怎么联系?  非常酷的网站设计制作软件,酷培ai教育官方网站?  建站168自助建站系统:快速模板定制与SEO优化指南  潍坊网站制作公司有哪些,潍坊哪家招聘网站好?  如何快速重置建站主机并恢复默认配置? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。