之前在使用模块时,还没有发现可以通过exports直接赋值,公开变量或者函数。其实,exports就像是module.exports的引用变量,而module.exports直接就相当于堆内存地址,所以,在最开始的时候,exports是指向module.exports的,即exports= module.exports={},而且默认返回的是module.exports。
- 验证默认返回的module.exports
创建一个js文件a.js,内容如下:
var key = 100;
exports =key;
module.exports=key;
return exports;
得到的打印结果如下:在执行exports =key;时,即 你把key值赋值给exports 打印出来的是空,但是,在执行module.exports=key;时,打印出来的是key的值

- exports 和module.exports关系的验证
1.在你给exports,赋值变量或者函数时,module.exports是可以取到exports添加的变量和函数的
var key = 100;
exports.key =key;
///module.exports=key;
return exports;
打印出来的结果如下:说明你在给exports做赋值操作时,module.exports是可以获取到exports的操作内容的。
2.在同时对exports和module.exports做赋值操作时,exports的赋值操作是无效的。
var key = 100;
exports.key =key;
function testFunc (argument) {
console.log(argument);
};
module.exports = {
testFunc:testFunc
};
return exports;
打印的结果如下:发现我再给module.exports赋值时,exports的赋值操作在module.exports中没有体现出来。