node.js中exports與Module.exports區別

          想你的模塊是一個特定的類型就用Module.exports。若是你想的模塊是一個典型的「實例化對象」就用exports。javascript

你確定很是熟悉nodejs模塊中的exports對象,你能夠用它建立你的模塊。例如:(假設這是rocker.js文件)java

複製代碼代碼以下:

exports.name = function() {  
console.log('My name is Lemmy Kilmister'); 
}; 


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

複製代碼代碼以下:

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的屬性。

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

複製代碼代碼以下:

module.exports = function(name, age) {  
this.name = name; 
this.age = age; 
this.about = function() { 
console.log(this.name +' is '+ this.age +' years old'); 
}; 
}; 


能夠這樣應用它: 
this

複製代碼代碼以下:

var Rocker = require('./rocker.js');  
var r = new Rocker('Ozzy', 62); 
r.about(); // Ozzy is 62 years old 


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

複製代碼代碼以下:

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


能夠這樣應用它: 
code

複製代碼代碼以下:

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'); 
}; 


一樣,exports是這樣的 

複製代碼代碼以下:

exports.name = function() {  
console.log('My name is Lemmy Kilmister'); 
}; 

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

相關文章
相關標籤/搜索