- 时间:2022-01-29 08:25 编辑: 来源: 阅读:
- 扫一扫,手机访问
摘要:详解Node.js中exports和module.exports的区别
今天看了下node.js的[code]require[/code]方法的源码,终于搞清楚exports和module.exports的区别了。
我们知道,node.js的模块暴露有两种方法。
[b]1. 方式一:用exports[/b]
//a.js
exports.log =function (str) {
console.log(str);
}
//b.js
var s = require("./a");
s.log("哈哈哈哈");
[b]2. 方式二:用module.exports
[/b]
//a.js
module.exports = function (str) {
console.log(str);
}
//b.js
var s = require("./a");
s("嘻嘻嘻嘻");
如果将第一种方式的exports按照第二种方式写成下面这样就会出错:
//a.js
exports = function (str) {
console.log(str);
}
//b.js
var s = require("./a");
s("哈哈哈哈");
[code]exports[/code]和[code]module.exports[/code]的初始值指向的是空对象,即[code]{}[/code]。从源码可以看到,其实模块的[code]require[/code]方法实质上是调用了[code]_load[/code]方法,而[code]_load[/code]方法,最终返回的是[code]module.exports[/code]
[img]http://img.1sucai.cn/uploads/article/2018010710/20180107100107_0_64253.png[/img]
[img]http://img.1sucai.cn/uploads/article/2018010710/20180107100108_1_54285.png[/img]
来分析一下出错的原因。
由于最开始的时候,[code]exports[/code]和[code]module.exports[/code]都指向同一个对象。
第一种方式,是在给这个空对象[code]{}[/code]添加属性,又因为[code]module.exports[/code]也是指向这个对象的,所以最终[code]require[/code]方法返回的[code]module.exports[/code]是指向了这个具有[code]log[/code]方法的对象的,可以引用到模块。
第二种方式是让[code]module.exports[/code]指向一片新的内存空间,[code]exports[/code]指向的仍然是[code]{}[/code],但是由于[code]require[/code]方法返回的是[code]module.exports[/code],所以最终也能引入模块。
但是最后那种写法是让[code]exports[/code]指向一片新的内存空间,[code]module.exports[/code]指向的仍然还是[code]{}[/code],那么最终[code]require[/code]方法是将[code]module.exports[/code]返回,所以会导致报错,说s不是一个function。
所以:
请牢记:[code]require[/code]方法返回的是[code]module.exports[/code]!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程素材网。