課程
/前端開發
/Node.js
/進擊Node.js基礎(一)
雖然老師說了傳統的模塊和那什么什么的(=_=),感覺概念還是不太清楚,有誰能詳細解釋一下,
module.exports和exports.attr在實際業務中我該如何選擇?
2016-01-20
源自:進擊Node.js基礎(一) 4-3
正在回答
你肯定非常熟悉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只不過是它的一個輔助工具?!∽罱K返回給調用的是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');?};?
同樣,exports是這樣的?
請注意,這兩種結果并不想同。前面已經提到module.exports是真正的接口,exports只不過是它的輔助工具。推薦使用exports導出,除非你打算從原來的“實例化對象”改變成一個類型。
碼上有媳婦 提問者
ping 127.0.0.1 -t
我直接用module.exports.name = "jack"; module.exports.age=12;也是可以替代exports.name, ? exports.age
理解深刻
舉報
本視頻教程帶你揭開Node.js的面紗,帶你走進一個全新世界
Copyright ? 2025 imooc.com All Rights Reserved | 京ICP備12003892號-11 京公網安備11010802030151號
購課補貼聯系客服咨詢優惠詳情
慕課網APP您的移動學習伙伴
掃描二維碼關注慕課網微信公眾號
2016-01-21
你肯定非常熟悉nodejs模塊中的exports對象,你可以用它創建你的模塊。例如:(假設這是rocker.js文件)
在另一個文件中你這樣引用
那到底Module.exports是什么呢?它是否合法呢??
其實,Module.exports才是真正的接口,exports只不過是它的一個輔助工具?!∽罱K返回給調用的是Module.exports而不是exports。
所有的exports收集到的屬性和方法,都賦值給了Module.exports。當然,這有個前提,就是Module.exports本身不具備任何屬性和方法。如果,Module.exports已經具備一些屬性和方法,那么exports收集來的信息將被忽略。
修改rocker.js如下:
再次引用執行rocker.js?
發現報錯:對象“ROCK IT!”沒有name方法?
rocker模塊忽略了exports收集的name方法,返回了一個字符串“ROCK IT!”。由此可知,你的模塊并不一定非得返回“實例化對象”。你的模塊可以是任何合法的javascript對象--boolean, number, date, JSON, string, function, array等等。
你的模塊可以是任何你設置給它的東西。如果你沒有顯式的給Module.exports設置任何屬性和方法,那么你的模塊就是exports設置給Module.exports的屬性。
下面例子中,你的模塊是一個類:?
可以這樣應用它:?
下面例子中,你的模塊是一個數組:?
可以這樣應用它:?
現在你明白了,如果你想你的模塊是一個特定的類型就用Module.exports。如果你想的模塊是一個典型的“實例化對象”就用exports。
給Module.exports添加屬性類似于給exports添加屬性。例如:?
同樣,exports是這樣的?
請注意,這兩種結果并不想同。前面已經提到module.exports是真正的接口,exports只不過是它的輔助工具。推薦使用exports導出,除非你打算從原來的“實例化對象”改變成一個類型。
2018-02-07
ping 127.0.0.1 -t
2017-06-26
我直接用module.exports.name = "jack"; module.exports.age=12;也是可以替代exports.name, ? exports.age
2016-08-11
理解深刻