首頁  >  文章  >  web前端  >  nodejs中exports與module.exports的差異詳細介紹_基礎知識

nodejs中exports與module.exports的差異詳細介紹_基礎知識

WBOY
WBOY原創
2016-05-16 17:43:411536瀏覽

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

複製程式碼 程式碼如下:
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');
複製程式碼


程式碼如下:


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'); 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導出,除非你打算從原來的「實例化物件」改變成一個類型。
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn