博客
关于我
module.exports和exports
阅读量:127 次
发布时间:2019-02-26

本文共 1147 字,大约阅读时间需要 3 分钟。

在Node.js中,模块化编程中的变量导出是通过module.exports和exports来实现的。这两个关键字看似相似,但实际上有细微的差别。理解这些差别对于写出高效且可维护的代码至关重要。

模块化编程中的变量导出

模块在Node.js中可以通过module.exports来导出变量、函数或对象供其他模块使用。module.exports实际上是模块的主要导出接口,用于向外暴露模块的功能和数据。

exports的作用

exports并非一个直接的导出接口,而是一个指向module.exports的引用。初始时,exports和module.exports指向同一个对象。当对exports进行赋值时,实际上是修改了module.exports所指向的对象。例如:

exports = {  name: 'Alice'}

这会导致module.exports也变成 { name: 'Alice' }。因此,修改exports会影响module.exports。

module.exports的作用

相比之下,module.exports是一个可控的接口,可以通过它重新导出变量或对象。例如:

module.exports = {  name: 'Alice'}

此时,exports仍然指向原来的对象,而module.exports被重新赋值为新的对象。这种行为允许开发者在不影响其他模块的情况下,重新导出变量或对象。

示例比较

  • 修改module.exports后,exports变化
  • module.exports.name = 123;console.log(exports); // { name: 123 }console.log('------------------');console.log(module); // { id: '.', exports: { name: 123 }, ... }
    1. 重新赋值module.exports,不影响exports
    2. exports.name = 123;module.exports = { name: 234 };console.log(exports); // { name: 123 }console.log('------------------');console.log(module); // { id: '.', exports: { name: 234 }, ... }

      总结

      理解这两者的区别对编写模块化代码至关重要。exports和module.exports在某些情况下会共享同一个对象,而在其他情况下则不会。使用module.exports重新导出变量是更安全和可控的选择,尤其是当需要重新导出对象时。

    转载地址:http://kohy.baihongyu.com/

    你可能感兴趣的文章
    MySQL分组查询
    查看>>
    Mysql分表后同结构不同名称表之间复制数据以及Update语句只更新日期加减不更改时间
    查看>>
    mySql分页Iimit优化
    查看>>
    MySQL分页查询
    查看>>
    mysql列转行函数是什么
    查看>>
    mysql创建函数报错_mysql在创建存储函数时报错
    查看>>
    mysql创建数据库和用户 并授权
    查看>>
    mysql创建数据库指定字符集
    查看>>
    MySql创建数据表
    查看>>
    MySQL创建新用户以及ERROR 1396 (HY000)问题解决
    查看>>
    MySQL创建用户与授权
    查看>>
    MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
    查看>>
    MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
    查看>>
    mysql初始密码错误问题
    查看>>
    Mysql删除重复数据通用SQL
    查看>>
    mysql判断某一张表是否存在的sql语句以及方法
    查看>>
    mysql加入安装策略_一键安装mysql5.7及密码策略修改方法
    查看>>
    mysql加强(1)~用户权限介绍、分别使用客户端工具和命令来创建用户和分配权限
    查看>>
    mysql加强(3)~分组(统计)查询
    查看>>
    mysql加强(4)~多表查询:笛卡尔积、消除笛卡尔积操作(等值、非等值连接),内连接(隐式连接、显示连接)、外连接、自连接
    查看>>