深入出不來Node module模塊

在開發複雜Web應用的時候,通常需要把各個功能進行拆分、封裝到不同的文件並在需要的時候引用該文件,即進行代碼的模塊化管理。幾乎所有的編程語言都有自己的模塊組織方式,比如Java中的包、C#中的程序集,而Node採用CommonJS模塊規範。

模塊規範

CommonJS旨在將運行在瀏覽器之外的JS進行標準化,並已經解決了大量的JS問題(如全局命名衝突)。Node對CommonJS的實現中,每個模塊都會被封裝在一個單獨的JS文件中,即一個文件就是一個模塊,而文件路徑就是模塊名。在編寫每個模塊時,都有以下三個預定義好的變量可供使用:
require()

該函數用於在當前模塊中加載和使用別的模塊,傳入一個模塊名,返回一個模塊導出對象。模塊名可以使用相對路徑(以./開頭),也可以使用絕對路徑(以/或C: 之類的盤符開頭)。另外,模塊名中的.js 擴展名是可以省略的,此時Node會尋找同名的文件夾,如果找不到,則尋找同名的js文件。還可以使用該函數加載和使用一個JSON文件,但此時.json 擴展名不可省略。
exports

該對象是當前模塊的導出對象,用於導出模塊公有方法和屬性,默認爲一個空對象{}。別的模塊通過require()函數使用當前模塊時得到的就是當前模塊的exports對象。以下代碼中導出了一個公有方法:

exports.hello = function() {
  console.log("Hello World!");
};

module

該對象用於提供當前模塊的元數據等相關信息,但用途最多的是使用其exports屬性替換當前模塊的導出對象。例如模塊導出對象默認是一個普通對象,可以使用以下方式使其變成一個函數:

module.exports = function() {
  console.log("Hello World!");
};

注意:當使用以上方式時,對exports對象的所有修改都將被忽略!

模塊初始化

一個模塊中的JS代碼僅在模塊第一次被使用時執行一次,並在執行過程中初始化模塊的導出對象。之後,緩存起來的導出對象被重複利用。
在test.js定義一個模塊

//定義私有變量
var name = "";
function setName(n) {
  name = n;
}
 
function logName() {
  console.log(name);
}
//導出公有方法
exports.setName = setName;
exports.logName = logName;

在main中加載test模塊

//加載test模塊
var test1 = require("./test.js"),
  test2 = require("./test.js");
 
//使用test1
test1.setName("Neo");
//使用test2
test2.logName(); //Neo

可見,無論調用多少次require() ,對於同一個模塊只加載一次,引用多次獲取的其實是相同的實例。
主模塊
通過命令行參數傳遞給Node以啓動程序的模塊稱爲主模塊,主模塊負責調度組成整個應用程序的其他模塊協同工作。例如通過以下命令行啓動程序時,main.js 就是主模塊:

$ node main.js

二進制模塊
Node除了可以使用JS編寫模塊,也支持使用C/C++編寫二進制模塊,編譯好的二進制模塊除了文件擴展名是.node外,和JS模塊的使用方式相同。雖然二進制模塊能使用操作系統提供的所有功能,但難以跨平臺使用。
結語

感謝您的觀看,如有不足之處,歡迎批評指正。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章