編寫(xiě)稍大一點(diǎn)的程序時(shí)一般都會(huì)將代碼模塊化。在 NodeJS 中,一般將代碼合理拆分到不同的 JS 文件中,每一個(gè)文件就是一個(gè)模塊,而文件路徑就是模塊名。
在編寫(xiě)每個(gè)模塊時(shí),都有 require、exports、module 三個(gè)預(yù)先定義好的變量可供使用。
require 函數(shù)用于在當(dāng)前模塊中加載和使用別的模塊,傳入一個(gè)模塊名,返回一個(gè)模塊導(dǎo)出對(duì)象。模塊名可使用相對(duì)路徑(以./開(kāi)頭),或者是絕對(duì)路徑(以/
或C:
之類(lèi)的盤(pán)符開(kāi)頭)。另外,模塊名中的.js
擴(kuò)展名可以省略。以下是一個(gè)例子。
var foo1 = require('./foo');
var foo2 = require('./foo.js');
var foo3 = require('/home/user/foo');
var foo4 = require('/home/user/foo.js');
// foo1 至 foo4 中保存的是同一個(gè)模塊的導(dǎo)出對(duì)象。另外,可以使用以下方式加載和使用一個(gè) JSON 文件。
var data = require('./data.json');
exports 對(duì)象是當(dāng)前模塊的導(dǎo)出對(duì)象,用于導(dǎo)出模塊公有方法和屬性。別的模塊通過(guò) require 函數(shù)使用當(dāng)前模塊時(shí)得到的就是當(dāng)前模塊的 exports 對(duì)象。以下例子中導(dǎo)出了一個(gè)公有方法。
exports.hello = function () {
console.log('Hello World!');
};
通過(guò) module 對(duì)象可以訪問(wèn)到當(dāng)前模塊的一些相關(guān)信息,但最多的用途是替換當(dāng)前模塊的導(dǎo)出對(duì)象。例如模塊導(dǎo)出對(duì)象默認(rèn)是一個(gè)普通對(duì)象,如果想改成一個(gè)函數(shù)的話(huà),可以使用以下方式。
module.exports = function () {
console.log('Hello World!');
};
以上代碼中,模塊默認(rèn)導(dǎo)出對(duì)象被替換為一個(gè)函數(shù)。
一個(gè)模塊中的 JS 代碼僅在模塊第一次被使用時(shí)執(zhí)行一次,并在執(zhí)行過(guò)程中初始化模塊的導(dǎo)出對(duì)象。之后,緩存起來(lái)的導(dǎo)出對(duì)象被重復(fù)利用。
通過(guò)命令行參數(shù)傳遞給 NodeJS 以啟動(dòng)程序的模塊被稱(chēng)為主模塊。主模塊負(fù)責(zé)調(diào)度組成整個(gè)程序的其它模塊完成工作。例如通過(guò)以下命令啟動(dòng)程序時(shí),main.js 就是主模塊。
$ node main.js
完整示例
例如有以下目錄。
- /home/user/hello/
- util/
counter.js
main.js
其中 counter.js 內(nèi)容如下:
var i = 0;
function count() {
return ++i;
}
exports.count = count;
該模塊內(nèi)部定義了一個(gè)私有變量 i,并在 exports 對(duì)象導(dǎo)出了一個(gè)公有方法 count。
主模塊 main.js 內(nèi)容如下:
var counter1 = require('./util/counter');
var counter2 = require('./util/counter');
console.log(counter1.count());
console.log(counter2.count());
console.log(counter2.count());
運(yùn)行該程序的結(jié)果如下:
$ node main.js
1
2
3
可以看到,counter.js 并沒(méi)有因?yàn)楸?require 了兩次而初始化兩次。
更多建議: