node.js里module.exports和exports区别
2022/2/25 20:22:27
本文主要是介绍node.js里module.exports和exports区别,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
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周岁' }。
这篇关于node.js里module.exports和exports区别的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-16Vue3资料:新手入门必读教程
- 2024-11-16Vue3资料:新手入门全面指南
- 2024-11-16Vue资料:新手入门完全指南
- 2024-11-16Vue项目实战:新手入门指南
- 2024-11-16React Hooks之useEffect案例详解
- 2024-11-16useRef案例详解:React中的useRef使用教程
- 2024-11-16React Hooks之useState案例详解
- 2024-11-16Vue入门指南:从零开始搭建第一个Vue项目
- 2024-11-16Vue3学习:新手入门教程与实践指南
- 2024-11-16Vue3学习:从入门到初级实战教程