詳解Node.js包的工程目錄與NPM包管理器的使用
工程目錄
了解了以上知識(shí)后,現(xiàn)在我們可以來(lái)完整地規(guī)劃一個(gè)工程目錄了。以編寫一個(gè)命令行程序?yàn)槔话阄覀儠?huì)同時(shí)提供命令行模式和 API 模式兩種使用方式,并且我們會(huì)借助三方包來(lái)編寫代碼。除了代碼外,一個(gè)完整的程序也應(yīng)該有自己的文檔和測(cè)試用例。因此,一個(gè)標(biāo)準(zhǔn)的工程目錄都看起來(lái)像下邊這樣。
- /home/user/workspace/node-echo/ # 工程目錄
- bin/ # 存放命令行相關(guān)代碼
node-echo
+ doc/ # 存放文檔
- lib/ # 存放API相關(guān)代碼
echo.js
- node_modules/ # 存放三方包
+ argv/
+ tests/ # 存放測(cè)試用例
package.json # 元數(shù)據(jù)文件
README.md # 說(shuō)明文件
其中部分文件內(nèi)容如下:
/* bin/node-echo */
var argv = require('argv'),
echo = require('../lib/echo');
console.log(echo(argv.join(' ')));
/* lib/echo.js */
module.exports = function (message) {
return message;
};
/* package.json */
{
"name": "node-echo",
"main": "./lib/echo.js"
}
以上例子中分類存放了不同類型的文件,并通過(guò) node_moudles 目錄直接使用三方包名加載模塊。此外,定義了package.json 之后,node-echo 目錄也可被當(dāng)作一個(gè)包來(lái)使用。
NPM
NPM 是隨同 NodeJS 一起安裝的包管理工具,能解決 NodeJS 代碼部署上的很多問(wèn)題,常見的使用場(chǎng)景有以下幾種:
- 允許用戶從 NPM 服務(wù)器下載別人編寫的三方包到本地使用。
- 允許用戶從 NPM 服務(wù)器下載并安裝別人編寫的命令行程序到本地使用。
- 允許用戶將自己編寫的包或命令行程序上傳到 NPM 服務(wù)器供別人使用。
可以看到,NPM 建立了一個(gè) NodeJS 生態(tài)圈,NodeJS 開發(fā)者和用戶可以在里邊互通有無(wú)。以下分別介紹這三種場(chǎng)景下怎樣使用 NPM。
下載三方包
需要使用三方包時(shí),首先得知道有哪些包可用。雖然 npmjs.org 提供了個(gè)搜索框可以根據(jù)包名來(lái)搜索,但如果連想使用的三方包的名字都不確定的話,就請(qǐng)百度一下吧。知道了包名后,比如上邊例子中的 argv,就可以在工程目錄下打開終端,使用以下命令來(lái)下載三方包。
$ npm install argv ... argv@0.0.2 node_modules\argv
下載好之后,argv 包就放在了工程目錄下的 node_modules 目錄中,因此在代碼中只需要通過(guò) require('argv')的方式就好,無(wú)需指定三方包路徑。
以上命令默認(rèn)下載最新版三方包,如果想要下載指定版本的話,可以在包名后邊加上@<version>,例如通過(guò)以下命令可下載 0.0.1 版的 argv。
$ npm install argv@0.0.1 ... argv@0.0.1 node_modules\argv
如果使用到的三方包比較多,在終端下一個(gè)包一條命令地安裝未免太人肉了。因此 NPM 對(duì) package.json 的字段做了擴(kuò)展,允許在其中申明三方包依賴。因此,上邊例子中的 package.json 可以改寫如下:
{
"name": "node-echo",
"main": "./lib/echo.js",
"dependencies": {
"argv": "0.0.2"
}
}
這樣處理后,在工程目錄下就可以使用 npm install 命令批量安裝三方包了。更重要的是,當(dāng)以后 node-echo 也上傳到了 NPM 服務(wù)器,別人下載這個(gè)包時(shí),NPM 會(huì)根據(jù)包中申明的三方包依賴自動(dòng)下載進(jìn)一步依賴的三方包。例如,使用 npm install node-echo 命令時(shí),NPM 會(huì)自動(dòng)創(chuàng)建以下目錄結(jié)構(gòu)。
- project/
- node_modules/
- node-echo/
- node_modules/
+ argv/
...
...
如此一來(lái),用戶只需關(guān)心自己直接使用的三方包,不需要自己去解決所有包的依賴關(guān)系。
安裝命令行程序
從 NPM 服務(wù)上下載安裝一個(gè)命令行程序的方法與三方包類似。例如上例中的 node-echo 提供了命令行使用方式,只要 node-echo 自己配置好了相關(guān)的 package.json 字段,對(duì)于用戶而言,只需要使用以下命令安裝程序。
$ npm install node-echo -g
參數(shù)中的 -g 表示全局安裝,因此 node-echo 會(huì)默認(rèn)安裝到以下位置,并且 NPM 會(huì)自動(dòng)創(chuàng)建好 Linux 系統(tǒng)下需要的軟鏈文件或 Windows 系統(tǒng)下需要的.cmd文件。
- /usr/local/ # Linux系統(tǒng)下
- lib/node_modules/
+ node-echo/
...
- bin/
node-echo
...
...
- %APPDATA%\npm\ # Windows系統(tǒng)下
- node_modules\
+ node-echo\
...
node-echo.cmd
...
發(fā)布代碼
第一次使用 NPM 發(fā)布代碼前需要注冊(cè)一個(gè)賬號(hào)。終端下運(yùn)行 npm adduser,之后按照提示做即可。賬號(hào)搞定后,接著我們需要編輯 package.json 文件,加入 NPM 必需的字段。接著上邊 node-echo 的例子,package.json 里必要的字段如下。
{
"name": "node-echo", # 包名,在NPM服務(wù)器上須要保持唯一
"version": "1.0.0", # 當(dāng)前版本號(hào)
"dependencies": { # 三方包依賴,需要指定包名和版本號(hào)
"argv": "0.0.2"
},
"main": "./lib/echo.js", # 入口模塊位置
"bin" : {
"node-echo": "./bin/node-echo" # 命令行程序名和主模塊位置
}
}
之后,我們就可以在 package.json 所在目錄下運(yùn)行 npm publish 發(fā)布代碼了。
版本號(hào)
使用 NPM 下載和發(fā)布代碼時(shí)都會(huì)接觸到版本號(hào)。NPM 使用語(yǔ)義版本號(hào)來(lái)管理代碼,這里簡(jiǎn)單介紹一下。
語(yǔ)義版本號(hào)分為 X.Y.Z 三位,分別代表主版本號(hào)、次版本號(hào)和補(bǔ)丁版本號(hào)。當(dāng)代碼變更時(shí),版本號(hào)按以下原則更新。
+ 如果只是修復(fù)bug,需要更新Z位。
+ 如果是新增了功能,但是向下兼容,需要更新Y位。
+ 如果有大變動(dòng),向下不兼容,需要更新X位。
版本號(hào)有了這個(gè)保證后,在申明三方包依賴時(shí),除了可依賴于一個(gè)固定版本號(hào)外,還可依賴于某個(gè)范圍的版本號(hào)。例如"argv": "0.0.x"表示依賴于 0.0.x 系列的最新版 argv。NPM 支持的所有版本號(hào)范圍指定方式可以查看官方文檔。
靈機(jī)一點(diǎn)
除了本章介紹的部分外,NPM 還提供了很多功能,package.json 里也有很多其它有用的字段。除了可以在 npmjs.org/doc/ 查看官方文檔外,這里再介紹一些 NPM 常用命令。
NPM 提供了很多命令,例如 install 和 publish,使用 npm help 可查看所有命令。
- 使用 npm help 可查看某條命令的詳細(xì)幫助,例如 npm help install。
- 在 package.json 所在目錄下使用npm install . -g可先在本地安裝當(dāng)前命令行程序,可用于發(fā)布前的本地測(cè)試。
- 使用npm update <package>可以把當(dāng)前目錄下 node_modules 子目錄里邊的對(duì)應(yīng)模塊更新至最新版本。
- 使用npm update <package> -g可以把全局安裝的對(duì)應(yīng)命令行程序更新至最新版。
- 使用npm cache clear可以清空 NPM 本地緩存,用于對(duì)付使用相同版本號(hào)發(fā)布新版本代碼的人。
- 使用npm unpublish <package>@<version>可以撤銷發(fā)布自己發(fā)布過(guò)的某個(gè)版本代碼。
相關(guān)文章
Node.js學(xué)習(xí)之查詢字符串解析querystring詳解
這篇文章主要給大家介紹了關(guān)于Node.js查詢字符串解析querystring的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用node.js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起看看吧。2017-09-09
node.js監(jiān)聽文件變化的實(shí)現(xiàn)方法
這篇文章主要給大家介紹了關(guān)于node.js監(jiān)聽文件變化的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用node.js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
如何用nodejs給C#寫一個(gè)數(shù)據(jù)表的實(shí)體類生成工具
這篇文章主要介紹了如何用nodejs給C#寫一個(gè)數(shù)據(jù)表的實(shí)體類生成工具,對(duì)nodejs感興趣的同學(xué),可以參考下2021-05-05
Express使用multer實(shí)現(xiàn)文件上傳的示例代碼
這篇文章主要介紹了Express 使用 multer 實(shí)現(xiàn)文件上傳的操作步驟,文中通過(guò)代碼示例和圖文結(jié)合的方式講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-03-03
簡(jiǎn)單了解node npm cnpm的具體使用方法
這篇文章主要介紹了簡(jiǎn)單了解node npm cnpm的具體使用方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-02-02
輕松創(chuàng)建nodejs服務(wù)器(4):路由
這篇文章主要介紹了輕松創(chuàng)建nodejs服務(wù)器(4):路由,服務(wù)器需要根據(jù)不同的URL或請(qǐng)求來(lái)執(zhí)行不一樣的操作,我們可以通過(guò)路由來(lái)實(shí)現(xiàn)這個(gè)步驟,需要的朋友可以參考下2014-12-12
從零開始學(xué)習(xí)Node.js系列教程一:http get和post用法分析
這篇文章主要介紹了從零開始學(xué)習(xí)Node.js系列教程一:http get和post用法,結(jié)合具體實(shí)例形式分析了nodejs中g(shù)et與post請(qǐng)求的使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2017-04-04

