exports 是 module.exports 的引用,类似如下所示:
const exports = module.exports
那如下结果会如何导出?很显然,会导出 100,毕竟 exports 进行了重指向。
module.exports = 100
exports = 3
exports 的实质
众所周知,node 中所有的模块代码都被包裹在这个函数中:
(function(exports, require, module, __filename, __dirname) {
exports.a = 3
});
在 node 源码 中,exports 的实现是这样的:
const dirname = path.dirname(filename);
const require = makeRequireFunction(this, redirects);
let result;
// 从这里可以看出来 exports 的实质
const exports = this.exports;
const thisValue = exports;
const module = this;
if (requireDepth === 0) statCache = new Map();
if (inspectorWrapper) {
result = inspectorWrapper(compiledWrapper, thisValue, exports, require, module, filename, dirname);
} else {
// 这里是模块包装函数
result = compiledWrapper.call(thisValue, exports, require, module, filename, dirname);
}
这两种使用起来到底有什么区别呢?
1、从返回上,exports返回的是模块函数;module.exports 返回的是模块对象本身,返回的是一个类。
exports.[function name] = [function name]
moudle.exports= [function name]
2、从使用上,exports的方法可以直接调用,module.exports需要new对象之后才可以调用。
PS:上新啦上新啦(^o^)/,该系列更新下集,详情出门右转→Node 中 exports 与 module.exports 有什么区别(下)
网友评论