(node中)module.exports 和exports的区别

(node中使用)module.exports 和exports的区别是什么?

用一句话来说明就是,require只会去引用module.exports这个对象的导出,不会引用exports对象的,而我们在编写模块时(初始化)用到的exports对象实际上只是对module.exports的引用。

来新建一个 module.js 文件:

console.log(exports === module.exports);

console.log(exports);

然后在命令行下运行 node module.js:

$ node module.js
true
{}

=== 判断结果为 true。这说明二者是一样的,指向同一个空对象 {}。

exports.pi = 3.14;
// vs
module.exports.pi = 3.14;
但是从模块使用者角度说,则二者是有区别的。
不具名数据

假设我作为模块使用者,要在我的代码中导入一个函数:

const func = require('./module');

则编写者只能使用 module.exports 来定义:

module.exports = function () {}

如果编写者使用 exports 来定义:

exports.func = function () {}

则使用者必须知道该函数的名称才能使用:

const { func } = require('./module');

把函数换成变量、常量或其它,也是一样道理。

注意对象

前面说,module.exports 与 exports 指向同一个空对象 {} - 且叫它 M。也就是说,不管是 exports.pi = 3.14 还是 module.exports.pi = 3.14,都是在操作 M 对象 - 在 Node/JavaScript 下。

但是对象是可变的,可以任意修改。(如果二者不指向同一个对象了,那么exports的导出,require会引用不到)因此我们可以直接给 exports 赋值:

exports = 3.14;

但这时,exports 就失去存在意义了。因为赋值以后,它不再指向对象 M,也就无法操作 M 对象,也就无法控制模块要导出的数据。所以上述写法是错误的,应该避免。

那么,给 module.exports 赋值对象以外的值呢

module.exports = 3.14;

这是没问题的(因为reuqiure寻找的就是module.exports这个对象的指向,现在它指向了“3.14” 这个字符串,),这说明模块默认导出一个数值,而不是 M 对象。

在 Node.js 模块里,真正控制模块导出的是 module.exports,exports 只是 module.exports 决定导出一个对象时的一个快捷方式,假如 module.exports 导出其它类型的数据,比如字符串、数值、函数等等,则 exports 的存在没有意义。这是 Node.js 模块与 CommonJS 差异的一点,在 CommonJS 规范里,是只有 exports,没有 module.exports 的。

又例如:

//test.js
const object = { na: "name", age: 18 }
exports = object;
//main.js
const ex = require("./test")
console.log("ex", ex);

输出为一个空对象
在这里插入图片描述

重要结论:module.exports 和 exports 同指一个对象,但是最终暴露结果以 module.exports 的为准,上面的代码中,exports 改变了指向,而我们又没有为 module.exports 挂载任何的属性或方法,所以就拿到了空对象。
画图举例:

在这里插入图片描述

刚开始 module.exports 和 exports 指向同一个对象

== 我们向外暴露时,是以 module.exports 为标准的 ==

总结

  1. exports 对象是 module 对象的一个属性,在初始时 module.exports 和 exports 指向同一块内存区域
  2. 模块导出的是 module.exports , exports 只是对它的引用,在不改变exports 内存的情况下,修改exports 的值可以改变 module.exports 的值
  3. 导出时尽量使用 module.exports ,以免因为各种赋值导致的混乱
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值