CommonJS采用同步加载和值拷贝,模块导出的是静态值;ES模块支持异步加载和动态引用,导出绑定保持实时更新,两者在加载机制、缓存策略及变量绑定上存在本质差异。

CommonJS和ES模块是JavaScript中两种主要的模块化规范,它们定义了代码如何被组织、导入和导出。CommonJS主要用于Node.js环境,采用同步加载;而ES模块是ECMAScript官方标准,支持异步加载,广泛应用于浏览器和现代Node.js。
讲到JavaScript的模块化,我总觉得这像是一场语言自身进化史上的重要篇章。一开始,我们的JS代码都是全局变量满天飞,命名冲突是家常便饭。后来,为了管理这种混乱,社区开始探索各种模式,比如IIFE(立即执行函数表达式),但这终究不是一个统一的解决方案。CommonJS和ES模块的出现,正是为了解决这个核心痛点:如何优雅、高效地组织和复用代码。
CommonJS,这个名字一听就知道它和“通用”计算有关。它诞生在服务器端,主要是Node.js的天下。它的核心思想是:每个文件都是一个独立的模块。你通过
require()
module.exports
exports
require
举个例子:
// math.js (CommonJS 模块)
function add(a, b) {
return a + b;
}
module.exports = { add };
// app.js
const { add } = require('./math');
console.log(add(2, 3)); // 输出 5这种模式简洁有效,让Node.js的生态系统迅速壮大。
然而,当JavaScript开始大规模进军浏览器端时,CommonJS的同步加载就显得力不从心了。浏览器需要从网络加载资源,同步加载会阻塞页面渲染,用户体验会非常糟糕。于是,ES模块(ECMAScript Modules),或者我们常说的ESM,应运而生,它被设计成JavaScript的官方模块标准,从一开始就考虑到了异步加载的需求。
ESM使用
import
export
// math.mjs (ES 模块)
export function add(a, b) {
return a + b;
}
// app.mjs
import { add } from './math.mjs';
console.log(add(2, 3)); // 输出 5注意到文件扩展名了吗?
.mjs
package.json
"type": "module"
所以,核心区别在于:CommonJS是Node.js的产物,同步加载,运行时确定依赖;ES模块是JS官方标准,异步加载,编译时确定依赖。它们各自有其历史背景和适用场景,但现在,整个生态都在朝着ES模块的方向靠拢。
网站模板是能够具有交互性,能够包含更多活跃的元素,就有必要在网页中嵌入其它的技术。如:Javascript、VBScript、Document Object Model(DOM,文档对象模型)、Layers和 Cascading Style Sheets(CSS,层叠样式表),这里主要讲Javascript。那么Javascript是什么东西?Javascript就是适应动态网页制作的需要而诞生的
70
Node.js作为JavaScript的运行时环境,一开始就选择了CommonJS作为其模块系统。这在当时是完全合理的,也极大地推动了Node.js的普及。但随着ES模块成为ECMAScript的官方标准,Node.js也面临了一个不可避免的问题:如何拥抱这个新标准,同时又不破坏现有的CommonJS生态?这是一个巨大的挑战,因为这两种模块系统在设计理念、加载机制、作用域处理上都有本质的区别。
最直接的挑战是互操作性。你不可能一夜之间把所有CommonJS模块都转换成ES模块,反之亦然。这就需要一个机制,让这两种模块能够相互调用。Node.js采取了一些策略:
.mjs
package.json
"type": "module"
import CJSModule from 'cjs-module';
module.exports
require()
import()
// cjs-app.js
async function main() {
const { add } = await import('./math.mjs'); // 动态导入
console.log(add(5, 5));
}
main();这种方式虽然解决了问题,但引入了异步性,使得代码结构变得复杂。
另一个挑战是模块解析机制。CommonJS的
require
import
index.js
再者,作用域和this
this
module.exports
this
undefined
这种双重支持虽然带来了灵活性,但也无疑增加了Node.js生态的复杂性,让初学者感到困惑,也让老开发者在项目迁移或新项目选型时需要深思熟虑。我们现在正处于一个过渡期,理解这些差异和挑战,对于编写健壮、可维护的Node.js应用至关重要。
深入理解CommonJS和ES模块,不能只停留在
require/exports
import/export
加载机制: CommonJS采用的是同步加载。这意味着当Node.js遇到
require()
module.exports
ES模块则采用异步加载。它的加载过程分为三个阶段:
模块缓存: 两种模块系统都支持模块缓存,以避免重复加载和执行。
require()
module.exports
require()
变量绑定(值拷贝 vs 引用): 这是两者之间一个非常重要的,也常常让人混淆的差异点。
以上就是什么是CommonJS和ES模块?的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号