JavaScript 規范(ECMAScript)沒有定義一套完善的能適用于大多數程序的標準庫。CommonJS 提供了一套 JavaScript 標準庫規范。Node 實現了 CommonJS 規范。
模塊基礎
在 Node 中,模塊和文件是一一對應的。我們定義一個模塊:
模塊的加載
Node 會對加載過的模塊進行緩沖,避免再次加載的開銷:
多次加載模塊 test.js
當加載文件沒有后綴時,Node 會嘗試添加后綴并加載:
1..js(JavaScript 源文件)
2..node(C/C++ 擴展模塊)
3..json(JSON 文件)
模塊主要有幾類:
1.核心模塊。核心模塊已經被編譯到了 Node 中,我們在其源碼中的 lib 目錄可以找到這些核心模塊。常見的核心模塊:net、http、fs 模塊等
2.文件模塊。文件模塊通過一個相對或者絕對路徑加載,例如我們上面看到的 circle.js
3.自定義模塊。自定義模塊位于 node_modules 目錄中,我們通過 npm 安裝的各種模塊就放置在 node_modules 目錄中
核心模塊總是優先被加載,假如有一個自定義模塊 http,那么加載時仍然會加載核心模塊 http 而非自定義模塊 http。在加載自定義模塊時,首先查找當前目錄下的 node_modules 目錄,而后查找父目錄下的 node_modules 目錄,以此類推,直到根目錄。
require 加載的模塊不是一個文件,而是一個目錄時,這樣的目錄被叫做包(package)。包中存在一個名為 package.json 的文件(包描述文件),例如:
其中 main 指出需要被加載的模塊。如果包中不存在 package.json 或者 package.json 中未指定 main 模塊,那么 Node 將會嘗試加載 index.js、index.node、index.json。
在加載 JavaScript 模塊時,被加載的模塊被包裹在一個函數中:
每個 JavaScript 模塊訪問到的 module、exports、__filename、__dirname 等實際上是通過函數參數傳遞進來的。由于這種包裹,才使得模塊的局部變量外部無法訪問。但有時候也會出現讓人難以理解的問題,例如:
test1.js
test2.js
加載這兩個模塊:
exports 作為參數傳遞給模塊,我們通過 exports.x 自然可以給 exports 對象添加屬性(或方法),但直接給 exports 賦值(例如,exports = x)僅僅是改變了形參而非實參的值,因此:
1.為 exports 添加屬性時,使用 exports
2.為 exports 賦值時,使用 module.exports
包
按 CommonJS 的規范,一個完整的包應該包含有:
1.package.json 包描述文件
2.bin 二進制文件目錄
3.lib JavaScript 代碼目錄
4.doc 文檔目錄
5.test 測試代碼目錄
NPM 是一個 Node 的一個包管理工具。常見用法:
查看命令的文檔:
查看命令 install 的文檔。
安裝一個包:
移除一個包:
新聞熱點
疑難解答