module.exports和exports export和export default的区别

3 篇文章 0 订阅
2 篇文章 0 订阅

一、module.exports和exports 的区别

CommonJS规范,经常能看到两种导出模块的方式:module.exports和exports。

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

从打印我们可以看出,module.exportsexports一开始都是一个空对象{},实际上,这两个对象指向同一块内存。这也就是说module.exports和exports是等价的(有个前提:不去改变它们指向的内存地址)。
例如:exports.age = 18module.export.age = 18,这两种写法是一致的(都相当于给最初的空对象{}添加了一个属性,通过require得到的就是{age: 18})。

但是

require引入的对象本质上是module.exports。这就产生了一个问题,当 module.exports和exports指向的不是同一块内存时,exports的内容就会失效。
例如:

module.exports = {name: '萤火虫叔叔'};
exports = {name: '萤火虫老阿姨'}

此时module.exports指向了一块新的内存(该内存的内容为{name: ‘萤火虫叔叔’}),exports指向了另一块新的内存(该内存的内容为{name: ‘萤火虫老阿姨’})。require得到的是{name: ‘萤火虫叔叔’}。

二、export和export default 的区别

  • export default

    export default导出
    //a.js
    const Programmer = {name: 'UncleFirefly',age:25}
    export default Programmer
    
    导入
    //b.js
    import Programmer from './a.js'
    
  • export

    export导出
    //a.js
    const uncle = {name: 'UncleFirefly',age:25}
    const aunt = {name: 'AuntFirefly',age:25}
    export {uncle, aunt}
    
    导入
    //b.js
    import {uncle, aunt} from './a.js'
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值