module.exports和exports使用误区案例分析

 更新时间:2023年04月03日 09:53:03   作者:๑Aurora.  
module.exports和exports使用误区,使用require()模块时,得到的永远都是module.exports指向的对象

module.exports和exports使用误区

使用require()模块时,得到的永远都是module.exports指向的对象

1.误区一

exports.username = 'zs'
exports.sayHello = function() {
    console.log('Hello!');
}

module.exports = {
    gender: '男',
    age: 20
}

在这里插入图片描述
在这里插入图片描述
因为默认情况下,exports 和 module.exports 指向同一个对象,二者开始都是指向一个空对象,当export指向新对象username="zs"后,此时二者都指向这 个对象,但是执行后面代码则是在内存中新开辟一个空间存储新对象 {gender:“男”,age:20} ,且把这个新对象的引用交给了module.exports,则module.exports就指向新的对象,不指向之前的对象了
所以这时候,如果使用require()模块,得到的就是module.exports此时指向的对象

注意此处的module.exports已经被重新定义!require()得到的是重新定义之后的导出对象!

2.误区二

module.exports.username = 'zs'

exports = {
    gender:'男',
    age:22
}

在这里插入图片描述
在这里插入图片描述
exports 和 module.exports 开始指向一个空对象,当module.export指向新对象username="zs"后,此时二者都指向这个对象,但是执行后面代码则是在内存 中新开辟一个空间存储新对象 {gender:“男”,age:20} ,且把这个新对象的引用交给了exports,但是module.exports指向对象 没有变,还是指向之前的对象
所以使用require()模块时,module.exports指向的对象还是原来的对象

注意:优先级还是module.exports的最高!!require()优先引用的还是module.exports所导出的对象!

3.误区三

exports.username = 'zs'

module.exports.gender = '男'

在这里插入图片描述
在这里插入图片描述
二者开始指向空对象,第一 行代码通过exports引用关系挂载了一个name属性,第二行又通过module.exports引用关系挂载了一个属性age 这里不存在新对象 都是挂载属性 这些属性都被放在了开始二者指向的对象中,最终两个属性都在此对象中
此时使用require()模块时,module.exports指向的对象没有变 ,但是此时指向对象上有两个属性

注意:这里的module.exports.gender = '男'在module.exports导出对象的基础上再次增加的属性,module.exports所指向的地址并没有改变!

4.误区四

exports = {
    uesrname: 'zs',
    gender: '男'
}

module.exports = exports
module.exports.age = 22

在这里插入图片描述
在这里插入图片描述

同理二者开始指向同一空对象,执行代码,在内存中定义了一个新对象,且把新对象挂载在exports上,此时exports就不指向之前的空对象 而指向新定义的对象,module.exports=exports这行代码把export的引用关系通过等号赋值给了module.exports,则module.exports也不指向之前的空对象了,也指向新对象了,最后给module.exports指向的新对象又继续挂载了一个age属性
此时使用require()模块时 ,module.exports指向的对象没有变,但是此时指向对象上有两个属性

谨记,使用require()模块时,得到的永远都是module.exports指向的对象
所以,为了防止这种混乱,以后在一个模块中,不 要同时使用exports和module.exports

相关文章

  • 如何在NestJS中添加对Shopify的WebHook验证详解

    如何在NestJS中添加对Shopify的WebHook验证详解

    这篇文章主要为大家介绍了如何在NestJS中添加对Shopify的WebHook验证详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-08-08
  • 详解nodejs通过响应回写的方式渲染页面资源

    详解nodejs通过响应回写的方式渲染页面资源

    本篇文章主要介绍了详解nodejs通过响应回写的方式渲染页面资源,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • node下使用UglifyJS压缩合并JS文件的方法

    node下使用UglifyJS压缩合并JS文件的方法

    下面小编就为大家分享一篇node下使用UglifyJS压缩合并JS文件的方法,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-03-03
  • 利用node+koa+axios实现图片上传和回显功能

    利用node+koa+axios实现图片上传和回显功能

    这篇文章为大家详细介绍了如何利用node+koa+axios实现图片上传和回显功能,主要实现简单的图片上传和静态内容的访问,感兴趣的可以了解一下
    2022-05-05
  • node.js使用cluster实现多进程

    node.js使用cluster实现多进程

    本文给大家详细介绍了nodejs使用cluster模块实现多进程的方法和步奏,非常的细致全面,有需要的小伙伴可以参考下
    2016-03-03
  • node.js读取命令行参数详解

    node.js读取命令行参数详解

    本文主要讲解了node.js如何获取命令行参数,有需要的朋友可以参考下
    2022-10-10
  • Node.js操作系统OS模块用法分析

    Node.js操作系统OS模块用法分析

    这篇文章主要介绍了Node.js操作系统OS模块用法,结合实例形式分析了nodejs OS模块常见函数功能及简单使用技巧,需要的朋友可以参考下
    2019-01-01
  • NodeJs实现简易WEB上传下载服务器

    NodeJs实现简易WEB上传下载服务器

    这篇文章主要为大家详细介绍了NodeJs实现一个简易WEB上传下载服务器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-08-08
  • nodejs语言实现验证码生成功能的示例代码

    nodejs语言实现验证码生成功能的示例代码

    这篇文章主要介绍了nodejs语言实现验证码生成功能的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-10-10
  • Express.JS使用详解

    Express.JS使用详解

    Express 是一个简洁而灵活的 node.js Web应用框架, 提供一系列强大特性帮助你创建各种Web应用。下面我们将逐步分析下,各位不要轻易离开
    2014-07-07

最新评论