exports对象是module对象的一个属性,在初始时二者指向同一个引用。module.exports初始的时候置为{},exports也指向这个空对象。
模块导出的是module.exports,我们在编写模块时用到的exports对象实际上只是对module.exports的引用(前提 在不改变exports的引用内存情况下)。推荐使用module.exports,以免因各种赋值导致错乱。
ECMAScript的变量类型有基本类型和引用类型两大类,引用类型:保存在内存中的对象,只能通过保存在变量中的地址引用对其进行操作。
这里讨论的exports和module.exports属于Object 引用类型。模块导出的是module.exports。之所以直接给exports添加属性外部可以拿到,是因为exports与module.exports指向同一个引用地址。当exports分配新的内存地址后,也就影响不到导出内容了。
例子:
var module = {
exports: {
age: '我今年18岁'
}
}
var exports = module.exports;
console.log(module.exports); // { age: '我今年18岁' }
console.log(exports); // { age: '我今年18岁' }
// 这里我们改变exports的属性age,改变的是同一个引用地址的数据!
exports.age = "准确的说我今年是18周岁";
console.log(module.exports); // { age: '准确的说我今年是18周岁' }
console.log(exports) // { age: '准确的说我今年是18周岁' }
// 这里我们直接给exports分配了一个新的内存地址,改变了原有的引用,此时exports和module.exports完全没关系了。
exports = {
age: '我是2002年出生,你算算我几岁',
}
console.log(module.exports); // { age: '准确的说我今年是18周岁' }
console.log(exports) // { age: '我是2002年出生,你算算我几岁' }
// 此时外部引用此文件,拿到的module.exports,也就是 { age: '准确的说我今年是18周岁' }。