在開發複雜Web應用的時候,一般須要把各個功能進行拆分、封裝到不一樣的文件並在須要的時候引用該文件,即進行代碼的模塊化管理。幾乎全部的編程語言都有本身的模塊組織方式,好比Java中的包、C#中的程序集,而Node採用CommonJS模塊規範。node
模塊規範編程
CommonJS旨在將運行在瀏覽器以外的JS進行標準化,並已經解決了大量的JS問題(如全局命名衝突)。Node對CommonJS的實現中,每一個模塊都會被封裝在一個單獨的JS文件中,即一個文件就是一個模塊,而文件路徑就是模塊名。在編寫每一個模塊時,都有如下三個預約義好的變量可供使用: require()json
該函數用於在當前模塊中加載和使用別的模塊,傳入一個模塊名,返回一個模塊導出對象。模塊名可使用相對路徑(以./開頭),也可使用絕對路徑(以/或C: 之類的盤符開頭)。另外,模塊名中的.js 擴展名是能夠省略的,此時Node會尋找同名的文件夾,若是找不到,則尋找同名的js文件。還可使用該函數加載和使用一個JSON文件,但此時.json 擴展名不可省略。 exports瀏覽器
該對象是當前模塊的導出對象,用於導出模塊公有方法和屬性,默認爲一個空對象{}。別的模塊經過require()函數使用當前模塊時獲得的就是當前模塊的exports對象。如下代碼中導出了一個公有方法:緩存
exports.hello = function() { console.log("Hello World!"); };//歡迎加入全棧開發交流圈一塊兒學習交流:864305860
module編程語言
該對象用於提供當前模塊的元數據等相關信息,但用途最多的是使用其exports屬性替換當前模塊的導出對象。例如模塊導出對象默認是一個普通對象,可使用如下方式使其變成一個函數:模塊化
module.exports = function() { console.log("Hello World!"); };
注意:當使用以上方式時,對exports對象的全部修改都將被忽略!函數
模塊初始化學習
一個模塊中的JS代碼僅在模塊第一次被使用時執行一次,並在執行過程當中初始化模塊的導出對象。以後,緩存起來的導出對象被重複利用。 在test.js定義一個模塊ui
//定義私有變量 var name = ""; function setName(n) { name = n; } function logName() { console.log(name); }//歡迎加入全棧開發交流圈一塊兒學習交流:864305860 //幫助突破技術瓶頸,提高思惟能力 //導出公有方法 exports.setName = setName; exports.logName = logName;
在main中加載test模塊
//加載test模塊 var test1 = require("./test.js"), test2 = require("./test.js"); //使用test1 test1.setName("Neo"); //歡迎加入全棧開發交流圈一塊兒學習交流:864305860 //使用test2 test2.logName(); //Neo
可見,不管調用多少次require() ,對於同一個模塊只加載一次,引用屢次獲取的實際上是相同的實例。 主模塊 經過命令行參數傳遞給Node以啓動程序的模塊稱爲主模塊,主模塊負責調度組成整個應用程序的其餘模塊協同工做。例如經過如下命令行啓動程序時,main.js 就是主模塊:
$ node main.js
二進制模塊 Node除了可使用JS編寫模塊,也支持使用C/C++編寫二進制模塊,編譯好的二進制模塊除了文件擴展名是.node外,和JS模塊的使用方式相同。雖然二進制模塊能使用操做系統提供的全部功能,但難以跨平臺使用。 結語
感謝您的觀看,若有不足之處,歡迎批評指正。