module.exports和exports的區(qū)別

在學習Node.js時,經(jīng)常能看到兩種導出模塊的方式:module.exportsexports。

穿插一個必備小知識:在文件a.js中用exportsmodule.exports導出的對象(方法、變量),可以在另一個文件b.js中通過require('./a')引用。

moduleexportsNode.js給每個js文件內(nèi)置的兩個對象??梢酝ㄟ^console.log(module)console.log(exports)打印出來。如果你在main.js中寫入下面兩行,然后運行$ node main.js:

console.log(exports);//輸出:{}
console.log(module);//輸出:Module {..., exports: {}, ...} (注:...代表省略了其他一些屬性)

從打印我們可以看出,module.exportsexports一開始都是一個空對象{},實際上,這兩個對象指向同一塊內(nèi)存。這也就是說module.exportsexports是等價的(有個前提:不去改變它們指向的內(nèi)存地址)。

例如:exports.age = 18module.export.age = 18,這兩種寫法是一致的(都相當于給最初的空對象{}添加了一個屬性,通過require得到的就是{age: 18})。

但是

require引入的對象本質(zhì)上是module.exports。這就產(chǎn)生了一個問題,當 module.exportsexports指向的不是同一塊內(nèi)存時,exports的內(nèi)容就會失效。
例如:

module.exports = {name: '螢火蟲叔叔'};
exports = {name: '螢火蟲老阿姨'}

此時module.exports指向了一塊新的內(nèi)存(該內(nèi)存的內(nèi)容為{name: '螢火蟲叔叔'}),exports指向了另一塊新的內(nèi)存(該內(nèi)存的內(nèi)容為{name: '螢火蟲老阿姨'})。require得到的是{name: '螢火蟲叔叔'}

附上代碼(在main.js中引入people.js):

//people.js
module.exports = {name: '螢火蟲叔叔'};
exports = {name: '螢火蟲老阿姨'};
//main.js
let people = require('./people');
console.log(people);//輸出:{name: '螢火蟲叔叔'}

歡迎加我微信,拉進群交流哦!


微信二維碼
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容