javascript中module.exports與exports的區(qū)別

module.exports與exports指向的是同一塊內(nèi)存區(qū)域,這個(gè)內(nèi)存區(qū)域里存著一個(gè)結(jié)構(gòu)體凌蔬,有諸多變量莺掠。到底有啥區(qū)別衫嵌?
app.js的代碼不變,如下:

varrocker=require("./log");
console.log(rocker.name);

首先彻秆,讓log.js的代碼成下面這個(gè)樣子:

exports.name=function(){
console.log('MynameisLemmyKilmister');
};
module.exports.name='ROCKIT!';

然后運(yùn)行node app.js楔绞,結(jié)果是 ROCK IT!
如果把log.js的代碼變成下面這個(gè)樣子:

module.exports.name='ROCKIT!';
exports.name=function(){
console.log('MynameisLemmyKilmister');
};

然后運(yùn)行node app.js,結(jié)果是[Function]唇兑。
這就很明顯了墓律,前后兩次的name指向的同一個(gè)內(nèi)存,相當(dāng)于把name變量重新賦值兩次幔亥。
如果把log.js的代碼變成下面一個(gè)樣子

module.exports='ROCKIT!';
exports.name=function(){
console.log('MynameisLemmyKilmister');
};

此時(shí)這個(gè)結(jié)構(gòu)體里啥屬性都沒有,只有一個(gè)字符串——ROCK IT察纯。所以它的結(jié)果是undefined

require 用來加載代碼帕棉,而 exports 和 module.exports 則用來導(dǎo)出代碼针肥。但很多新手可能會(huì)迷惑于 exports 和 module.exports 的區(qū)別,為了更好的理解 exports 和 module.exports 的關(guān)系香伴,我們先來鞏固下 js 的基礎(chǔ)慰枕。示例:

**test.js**
var a = {name: 1};
var b = a;
console.log(a);
console.log(b);
[b.name](http://b.name/) = 2;
console.log(a);
console.log(b);
var b = {name: 3};
console.log(a);
console.log(b);

運(yùn)行 test.js 結(jié)果為:
{ name: 1 }{ name: 1 }{ name: 2 }{ name: 2 }{ name: 2 }{ name: 3 }
解釋:a 是一個(gè)對(duì)象,b 是對(duì) a 的引用即纲,即 a 和 b 指向同一塊內(nèi)存具帮,所以前兩個(gè)輸出一樣。當(dāng)對(duì) b 作修改時(shí)低斋,即 a 和 b 指向同一塊內(nèi)存地址的內(nèi)容發(fā)生了改變蜂厅,所以 a 也會(huì)體現(xiàn)出來,所以第三四個(gè)輸出一樣膊畴。當(dāng) b 被覆蓋時(shí)掘猿,b 指向了一塊新的內(nèi)存,a 還是指向原來的內(nèi)存唇跨,所以最后兩個(gè)輸出不一樣稠通。
明白了上述例子后,我們只需知道三點(diǎn)就知道 exports 和 module.exports 的區(qū)別了:

  • module.exports 初始值為一個(gè)空對(duì)象 {}
  • exports 是指向的 module.exports 的引用
  • require() 返回的是 module.exports 而不是 exports

現(xiàn)在我們來看 Node.js 官方文檔的截圖:
屏幕快照 2016-09-29 上午11.59.44.png
屏幕快照 2016-09-29 上午11.59.44.png

我們經(jīng)陈虿看到這樣的寫法:
exports = module.exports = somethings

上面的代碼等價(jià)于:
module.exports = somethingsexports = module.exports

原理很簡(jiǎn)單改橘,即 module.exports 指向新的對(duì)象時(shí),exports 斷開了與 module.exports 的引用玉控,那么通過 exports = module.exports 讓 exports 重新指向 module.exports 即可飞主。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市奸远,隨后出現(xiàn)的幾起案子既棺,更是在濱河造成了極大的恐慌,老刑警劉巖懒叛,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件丸冕,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡薛窥,警方通過查閱死者的電腦和手機(jī)胖烛,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來诅迷,“玉大人佩番,你說我怎么就攤上這事“丈迹” “怎么了趟畏?”我有些...
    開封第一講書人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)滩租。 經(jīng)常有香客問我赋秀,道長(zhǎng)利朵,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任猎莲,我火速辦了婚禮绍弟,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘著洼。我一直安慰自己樟遣,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開白布身笤。 她就那樣靜靜地躺著豹悬,像睡著了一般。 火紅的嫁衣襯著肌膚如雪展鸡。 梳的紋絲不亂的頭發(fā)上屿衅,一...
    開封第一講書人閱讀 49,816評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音莹弊,去河邊找鬼涤久。 笑死,一個(gè)胖子當(dāng)著我的面吹牛忍弛,可吹牛的內(nèi)容都是我干的响迂。 我是一名探鬼主播,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼细疚,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼蔗彤!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起疯兼,我...
    開封第一講書人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤然遏,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后吧彪,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體待侵,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年姨裸,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了秧倾。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡傀缩,死狀恐怖那先,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情赡艰,我是刑警寧澤售淡,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響揖闸,放射性物質(zhì)發(fā)生泄漏苦掘。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一楔壤、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧惯驼,春花似錦蹲嚣、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至说贝,卻和暖如春议惰,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背乡恕。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來泰國(guó)打工言询, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人傲宜。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓运杭,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親函卒。 傳聞我的和親對(duì)象是個(gè)殘疾皇子辆憔,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • Node.js是目前非常火熱的技術(shù)报嵌,但是它的誕生經(jīng)歷卻很奇特虱咧。 眾所周知,在Netscape設(shè)計(jì)出JavaScri...
    w_zhuan閱讀 3,610評(píng)論 2 41
  • 【轉(zhuǎn)】 遵循的模塊化規(guī)范不一樣 模塊化規(guī)范:即為 JavaScript 提供一種模塊編寫锚国、模塊依賴和模塊運(yùn)行的方案...
    houruyaogeili閱讀 3,296評(píng)論 0 2
  • 原文:http://www.hacksparrow.com/node-js-exports-vs-module-e...
    geeksforgeeks閱讀 299評(píng)論 0 3
  • 前幾天跷叉,剛剛刪除微信好友里的幾個(gè)微商逸雹。是的,我會(huì)刪除我朋友圈的微商云挟。這個(gè)答案必須是肯定的梆砸。 首先,我是一個(gè)有著自己...
    孫曉麗閱讀 1,005評(píng)論 4 4
  • 我們?cè)跒g覽網(wǎng)站的時(shí)候經(jīng)常會(huì)看到一些類似亂碼的字符串园欣。這些是如何產(chǎn)生的呢帖世,又該怎么解決。 基本你所看到的網(wǎng)頁(yè)都是圖上...
    DX初學(xué)者閱讀 400評(píng)論 0 2