溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

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

發(fā)布時間:2020-08-20 14:14:32 來源:腳本之家 閱讀:171 作者:Young Dreamer 欄目:web開發(fā)

前言

之前使用過一些全局安裝的NPM包,安裝完之后,可以通過其提供的命令,完成一些任務(wù)。比如Fis3,可以通過fis3 server start 開啟fis的靜態(tài)文件服務(wù),通過fis3 release開啟文件編譯與發(fā)布;還有vue-cli,可以通過vue init webpack my-project來初始化vue+webpack的項目基礎(chǔ)配置。最近有一個需求,需要寫一個類似vue-cli的NPM包,通過命令行操作實現(xiàn)項目初始配置,所以就查看了相關(guān)資料,學(xué)習(xí)了一下如何使用node來生成自己的命令。

編寫命令行

命令的目標(biāo):在當(dāng)前目錄下開啟一個靜態(tài)文件服務(wù),端口號為8085

1.創(chuàng)建目錄

構(gòu)成命令的基礎(chǔ)是需要一個命令文件web.js和package.json配置文件,執(zhí)行以下命令:

$ mkdir node-commander #創(chuàng)建一個文件夾

$ cd node-commander && mkdir bin

$ npm init #初始化package.json文件<br>$ cd bin && touch web.js #創(chuàng)建命令文件

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)); 

文件的頭部務(wù)必加入#!/usr/bin/env node這行代碼,這里表示使用node作為腳本的解釋程序,node的路徑通過env來查找,可以避免node安裝路徑不一帶來的問題。

其中process為node進程中的全局變量,process.argv為一數(shù)組,數(shù)組內(nèi)存儲著命令行的各個部分,argv[0]為node的安裝路徑,argv[1]為主模塊文件路勁,剩下為子命令或參數(shù),如下:

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字段的作用:當(dāng)安裝npm包時,npm將添加一條命令/usr/local/bin/web,web命令軟連接到web.js文件。

調(diào)試命令行

(1)采用install方法

進入npm包目錄下,執(zhí)行全局install,根據(jù)package.json中bin的配置,為全局命令創(chuàng)建軟連。

# 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  

執(zhí)行web命令

# web --start

server start at port 8085

(2)采用npm link方法

npm link方法創(chuàng)建了兩個軟連,命令與命令文件的軟連,全局包與實際包文件的軟連。

# 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)進行操作了。

發(fā)布命令包

通過npm publish進行發(fā)布,前提是有npm帳號。如何操作可以查看npm 官方文檔。

本文是通過原生node.js來開發(fā)命令工具,而vue-cli是采用commander.js來簡化命令工具開發(fā),關(guān)于commander.js的使用方法,將在下一篇文章中介紹。

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI