module.exports和exports和export和export default的区别,import和require的区别

关于module.exportsexports的区别,我已经在前一篇文章讲过,传送门

在es5中,用module.exportsexports导出模块,用require引入模块。
es6新增exportexport default导出模块,import导入模块。

一、在es6中的两种基本用法

新建两个文件:a.js, b.jsa.js用于导出模块,b.js用户导入模块。两个文件放在同一目录下。

  • 第一种用法
    export default导出:

 

//a.js
const Programmer = {name: 'UncleFirefly',age:25}
export default Programmer

export default导出对应的导入:

 

//b.js
import Programmer from './a.js'
  • 第二种用法
    export导出:

 

//a.js
const uncle = {name: 'UncleFirefly',age:25}
const aunt = {name: 'AuntFirefly',age:25}
export {uncle, aunt}

export default导出对应的导入:

 

//b.js
import {uncle, aunt} from './a.js'

二、区别

可以在a.js中打印出module,通过打印的内容找到4种导出模块的区别。

  • exportsmodule.exports的区别
    查看exportsmodule.exports的区别请移步至我的另一篇文章:点我移步

  • exportexport default的区别

 

//a.js
const Programmer = {name: 'UncleFirefly',age:25}
export default Programmer
console.log(module)
/*
//打印结果
{exports: {default:{age:25,name:'UncleFirefly'}, hot:{...}}
*/

 

//a.js
const uncle = {name: 'UncleFirefly',age:25}
const aunt = {name: 'AuntFirefly',age:25}
export {uncle, aunt}
/*
//打印结果
{exports: {aunt:{age:25,name:'AuntFirefly'},uncle:{age:25,name:'UncleFirefly'}, hot:{...}}
*/

从打印可以看出:

  • 导出时

    • export相当于把对象添加到moduleexports中。
    • export default相当于把对象添加到moduleexports中,并且对象的key叫default
  • 导入时:

    • 不带{}的导入
      本质上就是导入exports中的default属性(注:如果default属性不存在,则导入exports对象)。

    • {}的导入
      本质上按照属性key值导入exports中对应的属性值。

三、小tips

一般来说,module.exportsexportsrequire对应。也就是用module.exportsexports导出的模块,则用require导入。(不是绝对,如果代码支持es6,也可以用import引入)。

 

 

-----------------------------------------

 

 

module.exports和exports的区别

 

在学习Node.js时,经常能看到两种导出模块的方式:module.exportsexports

穿插一个必备小知识:在文件a.js中用exportsmodule.exports导出的对象(方法、变量),可以在另一个文件b.js中通过require('./a')引用。

moduleexportsNode.js给每个js文件内置的两个对象。可以通过console.log(module)console.log(exports)打印出来。如果你在main.js中写入下面两行,然后运行$ node main.js:

 

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

从打印我们可以看出,module.exportsexports一开始都是一个空对象{}实际上,这两个对象指向同一块内存。这也就是说module.exportsexports是等价的(有个前提:不去改变它们指向的内存地址)。

例如:exports.age = 18module.export.age = 18,这两种写法是一致的(都相当于给最初的空对象{}添加了一个属性,通过require得到的就是{age: 18})。

但是

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

 

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

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

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

 

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

 

//main.js
let people = require('./people');
console.log(people);//输出:{name: '萤火虫叔叔'}


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值