module.exports和exports

module.exportsexports

本质上,exportsmodule.exports对象的引用ui

JS引用

var a = {x: "2"};
var b = a;
console.log(a);  // { x: '2' }
console.log(b);  // { x: '2' }

b.x = 3;
console.log(a);  // { x: 3 }
console.log(b);  // { x: 3 }

b = {x: 1};
console.log(a);  // { x: 3 }
console.log(b);  // { x: 1 }

console.log(module.exports === exports);   // true
  • 变量a是一个对象,而ba的引用(ab指向同一块内存),因此输出相同code

  • b修改原对象后,由于ab指向同一块内存,因此修改会体如今a对象

  • b被覆盖时,b指向了一块新的内存;而a的指向不变,因此输出不一样内存

module.exportsexports的区别

  • module.exports的初始值是一个空对象{}console

  • exportsmodule.exports对象的一个引用class

  • require()返回值的是module.exports对象,而非exportsrequire

重置module.exportsexports,指向一个新对象时,会断开两者间的引用关系变量

使用方式

  • 如下两种写法相同,module.exports指向一个新对象,断开两者间的联系module

  • 再使用exports = module.exports使exports指向新对象,恢复两者间的联系引用

    exports = module.exports = {...};
    
    /*
     * module.exports = {...};
     * exports = module.exports;
     */
相关文章
相关标签/搜索