W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
編寫稍大一點(diǎn)的程序時(shí)一般都會(huì)將代碼模塊化。在NodeJS中,一般將代碼合理拆分到不同的JS文件中,每一個(gè)文件就是一個(gè)模塊,而文件路徑就是模塊名。
在編寫每個(gè)模塊時(shí),都有require
、exports
、module
三個(gè)預(yù)先定義好的變量可供使用。
require
函數(shù)用于在當(dāng)前模塊中加載和使用別的模塊,傳入一個(gè)模塊名,返回一個(gè)模塊導(dǎo)出對(duì)象。模塊名可使用相對(duì)路徑(以./
開頭),或者是絕對(duì)路徑(以/
或C:
之類的盤符開頭)。另外,模塊名中的.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ù)的話,可以使用以下方式。
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)程序的模塊被稱為主模塊。主模塊負(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)楸籸equire了兩次而初始化兩次。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: