W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
編寫稍大一點的程序時一般都會將代碼模塊化。在 NodeJS 中,一般將代碼合理拆分到不同的 JS 文件中,每一個文件就是一個模塊,而文件路徑就是模塊名。
在編寫每個模塊時,都有 require、exports、module 三個預先定義好的變量可供使用。
require 函數(shù)用于在當前模塊中加載和使用別的模塊,傳入一個模塊名,返回一個模塊導出對象。模塊名可使用相對路徑(以./開頭),或者是絕對路徑(以/
或C:
之類的盤符開頭)。另外,模塊名中的.js
擴展名可以省略。以下是一個例子。
var foo1 = require('./foo');
var foo2 = require('./foo.js');
var foo3 = require('/home/user/foo');
var foo4 = require('/home/user/foo.js');
// foo1 至 foo4 中保存的是同一個模塊的導出對象。另外,可以使用以下方式加載和使用一個 JSON 文件。
var data = require('./data.json');
exports 對象是當前模塊的導出對象,用于導出模塊公有方法和屬性。別的模塊通過 require 函數(shù)使用當前模塊時得到的就是當前模塊的 exports 對象。以下例子中導出了一個公有方法。
exports.hello = function () {
console.log('Hello World!');
};
通過 module 對象可以訪問到當前模塊的一些相關(guān)信息,但最多的用途是替換當前模塊的導出對象。例如模塊導出對象默認是一個普通對象,如果想改成一個函數(shù)的話,可以使用以下方式。
module.exports = function () {
console.log('Hello World!');
};
以上代碼中,模塊默認導出對象被替換為一個函數(shù)。
一個模塊中的 JS 代碼僅在模塊第一次被使用時執(zhí)行一次,并在執(zhí)行過程中初始化模塊的導出對象。之后,緩存起來的導出對象被重復利用。
通過命令行參數(shù)傳遞給 NodeJS 以啟動程序的模塊被稱為主模塊。主模塊負責調(diào)度組成整個程序的其它模塊完成工作。例如通過以下命令啟動程序時,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)部定義了一個私有變量 i,并在 exports 對象導出了一個公有方法 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());
運行該程序的結(jié)果如下:
$ node main.js
1
2
3
可以看到,counter.js 并沒有因為被 require 了兩次而初始化兩次。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: