尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

【模块化解读】commonjs vs commonjs2 exports vs module.exports

【模块化解读】commonjs vs commonjs2  exports vs module.exports
📅 发布时间:2026/6/19 3:23:35

背景

最近在用typescript写工具库的时候,无意中在 webpack中看到了两个关键字,commonjs 和 commonjs2. 瞬间产生了好奇。后面看了issues才得知它们与模块化 导出有着密切关系。

CommonJs spec defines only exports. But module.exports is used by node.js and many other CommonJs implementations.
commonjs mean pure CommonJs
commonjs2 also includes the module.exports stuff.

大致意思是:
CommonJs规范仅定义出口。但是模块。使用出口节点。js和许多其他CommonJs的实现。
commonjs的意思是纯commonjs
commonjs2还包括模块。出口的东西。

这里引用了 https://github.com/webpack/webpack/issues/1114 的回答,commonjs vs commonjs2 这两个概念问题迎刃而解。大家可自行阅览

那到底module.exports vs exports 区别是什么呢?

自己查阅了很多文章,仍然很懵,但觉得这篇文章https://www.sitepoint.com/understanding-module-exports-exports-node-js/ 解释得比较到位。

我所理解的关键点:
1.require的大致实现:

	var require = function(path) { // ... return module.exports; };

2.module.exports => {} <= exports 指向同一个对象。 两者最好不要同时使用。

// exports 仅适用于:exports.a = 'xxx';// module.exports 适用于module.exports = 'xxx';
module.exports.a = 'xxx';

那么问题来了好像export能做的,module.export都能满足。所以产生疑问,知识才有了拓展的可能。

3.其实2中的疑问一点也没错,nodejs 官方文档中提及https://nodejs.org/docs/latest/api/modules.html#modules_exports_alias exports
只是module.exports的一个别名 还提示当你搞不清楚的时候,就用module.exports。

总结

1.commonjs 规范只定义了exports,而 module.exports是nodejs对commonjs的实现,实现往往会在满足规范前提下作些扩展,我们这里把这种实现称为了commonjs2

2.module.exports 是nodejs对commonjs的具体实现。exports 只是它的一个别名。搞不清楚关系的时候可以不用这个别名。

戏言: 不知不觉头发丝儿又少了几根,“呜呜呜呜,码仔痛哭“

相关新闻

  • PHP 8.5 新特性 闭包可以作为常量表达式了
  • 【JavaScript-基础】map、forEach、for、for in、for of等的区别
  • dotnet 利用 Windows 注册表实现开机自动启动

最新新闻

  • 【共创季稿事节】HarmonyOS7 互动卡片开发实践:从 0 看懂 LiveCard 项目的主链路
  • 终极FitGirl游戏启动器:一站式游戏下载与管理解决方案
  • MPC857T UPM内存控制器高级特性解析:时序、等待与多主系统设计
  • 复古视频美学:从技术缺陷到视觉语言的完整创作指南
  • 2026年企业级AI API聚合平台观察:稳定性、协议兼容与模型生态能力全景分析
  • 终极Windows USB设备安全弹出解决方案:告别“设备正在使用中“的烦恼

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号