本文共 885 字,大约阅读时间需要 2 分钟。
在模块化编程中,模块的导出方式有两种主要方法,分别是exports和module.exports。了解这两种方法的区别及其适用场景,对于理解模块导出机制具有重要意义。
在初始阶段,exports和module.exports实际上是指向同一块内存区域,内容都是一个空对象。具体来说:
exports === module.exports // 输出是 true
这意味着在定义模块时,无论直接使用exports还是module.exports赋值,结果都是一样的。例如:
//1 mymodule.jsexports.f = function() {}exports.pi = 3.1415926//2 mymodule.jsmodule.exports.f = function() {}module.exports.pi = 3.1415926 两种写法的效果完全一致。
需要注意的是,当直接将exports对象赋值时(例如:exports={a:1,b:2}),此时exports就不再指向module.exports,而是指向一个新对象。这种情况下,exports与module.exports就不再是同一个对象。
在引入某模块时,应以该模块代码中module.exports指向的内容为准。例如:
// mymodule.jsmodule.exports = { myPI: 3.14, add: (a, b) => a + b} 这种方式是最常见且推荐的导出方式。
在实际开发中,许多模块采用不同的导出方式。例如:
cookie模块通常使用module.exports的形式导出。body-parser模块同样采用module.exports的方式。array-flatten模块也遵循这一规则。在导出模块时,建议只使用一种方式,并且建议直接使用module.exports。这不仅简化了代码,也符合大多数模块的标准导出方式。
转载地址:http://ddca.baihongyu.com/