nodejs中exports與module.exports的區(qū)別詳細介紹
更新時間:2013年01月14日 17:59:29 作者:
你肯定非常熟悉nodejs模塊中的exports對象,你可以用它創(chuàng)建你的模塊接下來介紹創(chuàng)建過程,感興趣的朋友可以參考下
你肯定非常熟悉nodejs模塊中的exports對象,你可以用它創(chuàng)建你的模塊。例如:(假設(shè)這是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只不過是它的一個輔助工具。 最終返回給調(diào)用的是Module.exports而不是exports。
所有的exports收集到的屬性和方法,都賦值給了Module.exports。當然,這有個前提,就是Module.exports本身不具備任何屬性和方法。如果,Module.exports已經(jīng)具備一些屬性和方法,那么exports收集來的信息將被忽略。
修改rocker.js如下:
module.exports = 'ROCK IT!';
exports.name = function() {
console.log('My name is Lemmy Kilmister');
};
再次引用執(zhí)行rocker.js
var rocker = require('./rocker.js');
rocker.name(); // TypeError: Object ROCK IT! has no method 'name'
發(fā)現(xiàn)報錯:對象“ROCK IT!”沒有name方法
rocker模塊忽略了exports收集的name方法,返回了一個字符串“ROCK IT!”。由此可知,你的模塊并不一定非得返回“實例化對象”。你的模塊可以是任何合法的javascript對象--boolean, number, date, JSON, string, function, array等等。
你的模塊可以是任何你設(shè)置給它的東西。如果你沒有顯式的給Module.exports設(shè)置任何屬性和方法,那么你的模塊就是exports設(shè)置給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');
};
};
可以這樣應(yīng)用它:
var Rocker = require('./rocker.js');
var r = new Rocker('Ozzy', 62);
r.about(); // Ozzy is 62 years old
下面例子中,你的模塊是一個數(shù)組:
module.exports = ['Lemmy Kilmister', 'Ozzy Osbourne', 'Ronnie James Dio', 'Steven Tyler', 'Mick Jagger'];
可以這樣應(yīng)用它:
var rocker = require('./rocker.js');
console.log('Rockin in heaven: ' + rocker[2]); //Rockin in heaven: Ronnie James Dio
現(xiàn)在你明白了,如果你想你的模塊是一個特定的類型就用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');
};
請注意,這兩種結(jié)果并不想同。前面已經(jīng)提到module.exports是真正的接口,exports只不過是它的輔助工具。推薦使用exports導出,除非你打算從原來的“實例化對象”改變成一個類型。
復制代碼 代碼如下:
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只不過是它的一個輔助工具。 最終返回給調(diào)用的是Module.exports而不是exports。
所有的exports收集到的屬性和方法,都賦值給了Module.exports。當然,這有個前提,就是Module.exports本身不具備任何屬性和方法。如果,Module.exports已經(jīng)具備一些屬性和方法,那么exports收集來的信息將被忽略。
修改rocker.js如下:
復制代碼 代碼如下:
module.exports = 'ROCK IT!';
exports.name = function() {
console.log('My name is Lemmy Kilmister');
};
再次引用執(zhí)行rocker.js
復制代碼 代碼如下:
var rocker = require('./rocker.js');
rocker.name(); // TypeError: Object ROCK IT! has no method 'name'
發(fā)現(xiàn)報錯:對象“ROCK IT!”沒有name方法
rocker模塊忽略了exports收集的name方法,返回了一個字符串“ROCK IT!”。由此可知,你的模塊并不一定非得返回“實例化對象”。你的模塊可以是任何合法的javascript對象--boolean, number, date, JSON, string, function, array等等。
你的模塊可以是任何你設(shè)置給它的東西。如果你沒有顯式的給Module.exports設(shè)置任何屬性和方法,那么你的模塊就是exports設(shè)置給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');
};
};
可以這樣應(yīng)用它:
復制代碼 代碼如下:
var Rocker = require('./rocker.js');
var r = new Rocker('Ozzy', 62);
r.about(); // Ozzy is 62 years old
下面例子中,你的模塊是一個數(shù)組:
復制代碼 代碼如下:
module.exports = ['Lemmy Kilmister', 'Ozzy Osbourne', 'Ronnie James Dio', 'Steven Tyler', 'Mick Jagger'];
可以這樣應(yīng)用它:
復制代碼 代碼如下:
var rocker = require('./rocker.js');
console.log('Rockin in heaven: ' + rocker[2]); //Rockin in heaven: Ronnie James Dio
現(xiàn)在你明白了,如果你想你的模塊是一個特定的類型就用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');
};
請注意,這兩種結(jié)果并不想同。前面已經(jīng)提到module.exports是真正的接口,exports只不過是它的輔助工具。推薦使用exports導出,除非你打算從原來的“實例化對象”改變成一個類型。
相關(guān)文章
解析DHTML,JavaScript,DOM,BOM以及WEB標準的描述
本篇文章是對DHTML,JavaScript,DOM,BOM以及WEB標準進行了詳細的描述介紹,需要的朋友參考下2013-06-06