nodejs中exports與module.exports的區別詳細介紹

看瞭好多篇關於exports與module.exports的區別的介紹,好多感覺講的都不夠準確,最後才明白兩者用法的區別為:如果你想你的模塊是一個特定的類型就用Module.exports。如果你想的模塊是一個典型的“實例化對象”就用exports。

你肯定非常熟悉nodejs模塊中的exports對象,你可以用它創建你的模塊。例如:(假設這是rocker.js文件) 

代碼如下:

 

exports.name = function() { 

console.log('My name is Lemmy Kilmister'); 

}; 

 

在另一個文件中你這樣引用 

代碼如下:

 

var rocker = require('./rocker.js'); 

rocker.name(); // 'My name is Lemmy Kilmister' 

 

那到底Module.exports是什麼呢?它是否合法呢? 

其實,Module.exports才是真正的接口,exports隻不過是它的一個輔助工具。 最終返回給調用的是Module.exports而不是exports。

 

所有的exports收集到的屬性和方法,都賦值給瞭Module.exports。當然,這有個前提,就是Module.exports本身不具備任何屬性和方法。如果,Module.exports已經具備一些屬性和方法,那麼exports收集來的信息將被忽略。

 

修改rocker.js如下: 

代碼如下:

 

module.exports = 'ROCK IT!'; 

exports.name = function() { 

console.log('My name is Lemmy Kilmister'); 

}; 

 

再次引用執行rocker.js 

代碼如下:

 

var rocker = require('./rocker.js'); 

rocker.name(); // TypeError: Object ROCK IT! has no method 'name' 

 

發現報錯:對象“ROCK IT!”沒有name方法 

rocker模塊忽略瞭exports收集的name方法,返回瞭一個字符串“ROCK IT!”。由此可知,你的模塊並不一定非得返回“實例化對象”。你的模塊可以是任何合法的javascript對象–boolean, number, date, JSON, string, function, array等等。

 

你的模塊可以是任何你設置給它的東西。如果你沒有顯式的給Module.exports設置任何屬性和方法,那麼你的模塊就是exports設置給Module.exports的屬性。

 

下面例子中,你的模塊是一個類: 

代碼如下:

 

module.exports = function(name, age) { 

this.name = name; 

this.age = age; 

this.about = function() { 

console.log(this.name +' is '+ this.age +' years old'); 

}; 

}; 

 

可以這樣應用它: 

代碼如下:

 

var Rocker = require('./rocker.js'); 

var r = new Rocker('Ozzy', 62); 

r.about(); // Ozzy is 62 years old 

 

下面例子中,你的模塊是一個數組: 

代碼如下:

 

module.exports = ['Lemmy Kilmister', 'Ozzy Osbourne', 'Ronnie James Dio', 'Steven Tyler', 'Mick Jagger']; 

 

可以這樣應用它: 

代碼如下:

 

var rocker = require('./rocker.js'); 

console.log('Rockin in heaven: ' + rocker[2]); //Rockin in heaven: Ronnie James Dio 

 

現在你明白瞭,如果你想你的模塊是一個特定的類型就用Module.exports。如果你想的模塊是一個典型的“實例化對象”就用exports。

 

給Module.exports添加屬性類似於給exports添加屬性。例如: 

代碼如下:

 

module.exports.name = function() { 

console.log('My name is Lemmy Kilmister'); 

}; www.2cto.com

 

同樣,exports是這樣的 

代碼如下:

 

exports.name = function() { 

console.log('My name is Lemmy Kilmister'); 

}; 

 

請註意,這兩種結果並不想同。前面已經提到module.exports是真正的接口,exports隻不過是它的輔助工具。推薦使用exports導出,除非你打算從原來的“實例化對象”改變成一個類型。

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。 必填欄位標示為 *