0

0

CommonJS和ES模块有什么区别

畫卷琴夢

畫卷琴夢

发布时间:2025-08-17 15:31:01

|

471人浏览过

|

来源于php中文网

原创

commonjs采用同步加载,es模块采用异步加载;2. commonjs使用require和module.exports,es模块使用import和export;3. commonjs适用于node.js环境,es模块适用于浏览器及现代node.js环境;4. commonjs处理循环依赖时可能获取未初始化值,es模块通过拓扑排序可靠处理;5. commonjs不支持动态导入,es模块支持import()动态加载;6. node.js需设置"type": "module"并使用.mjs或.js文件启用es模块;7. 浏览器需通过打包工具将commonjs转换为可运行格式;8. 未来es模块将逐渐取代commonjs成为主流模块化方案。

CommonJS和ES模块有什么区别

CommonJS和ES模块是JavaScript中两种不同的模块化方案,主要区别在于加载方式、语法和适用场景。CommonJS主要用于Node.js环境,采用运行时加载;ES模块则主要用于浏览器环境,采用静态编译。

CommonJS和ES模块的区别

模块加载方式的区别

CommonJS使用

require
同步加载模块。这意味着在代码执行到
require
语句时,会立即加载并执行对应的模块。这种方式在服务器端环境下表现良好,因为文件系统访问速度快。但在浏览器端,同步加载会导致页面阻塞,影响用户体验。

ES模块使用

import
异步加载模块。浏览器可以在解析HTML时预先加载ES模块,或者使用动态
import()
在运行时按需加载。这种方式避免了页面阻塞,提高了加载效率。ES模块还支持静态分析,可以在编译时进行优化。

语法上的差异

CommonJS使用

exports
module.exports
导出模块,使用
require
导入模块。例如:

// module.js
exports.myFunction = function() {
  console.log('Hello from CommonJS module!');
};

// main.js
const module = require('./module');
module.myFunction();

ES模块使用

export
导出模块,使用
import
导入模块。例如:

// module.js
export function myFunction() {
  console.log('Hello from ES module!');
}

// main.js
import { myFunction } from './module.js';
myFunction();

ES模块的语法更加灵活,支持命名导出和默认导出。命名导出可以导出多个变量、函数或类,而默认导出只能导出一个值。

适用场景的不同

CommonJS最初是为Node.js设计的,因此在服务器端JavaScript环境中广泛使用。它适用于构建命令行工具、服务器应用等。

ES模块是JavaScript官方的模块化标准,主要用于浏览器端。它适用于构建大型Web应用、SPA等。随着Node.js对ES模块的支持越来越完善,ES模块也逐渐在Node.js环境中得到应用。

循环依赖的处理方式

CommonJS在处理循环依赖时,会先执行当前模块,然后将

exports
对象传递给依赖模块。如果依赖模块在当前模块执行之前就访问了
exports
对象,可能会得到未完全初始化的值。

全诚外卖通外卖预订管理系统单店版
全诚外卖通外卖预订管理系统单店版

一、外卖通叫餐(预订)系统单店版是什么样的一个系统? 外卖通系列软件是针对非商品性买卖、有别于传统的商城系统的、外卖和预订为概念性的店铺管理系统,我们的口号就是:让所有的门店在网上安个家,以往的版本都是基于多用户性质的平台系统,而外卖通单店版是基于某个店铺的专业外卖预订管理系统,设计了外卖、预订、专题活动、小游戏、资讯、形象、点评、积分、相册等多种功能模块以适应商家办站的各种需求。这套系统可

下载

ES模块在处理循环依赖时,会先解析所有模块的依赖关系,然后按照拓扑排序的顺序执行模块。这样可以避免循环依赖导致的问题。ES模块的这种处理方式更加可靠。

是否支持动态导入

CommonJS不支持动态导入。只能在代码中使用

require
同步加载模块。

ES模块支持动态导入。可以使用

import()
函数在运行时按需加载模块。这对于代码分割、懒加载等场景非常有用。例如:

async function loadModule() {
  const module = await import('./module.js');
  module.myFunction();
}

loadModule();

动态导入可以提高应用的性能和用户体验。

如何在Node.js中使用ES模块

Node.js从v13.2.0开始正式支持ES模块。要使用ES模块,需要满足以下条件:

  1. 文件扩展名为
    .mjs
    .js
    ,并且在
    package.json
    中设置
    "type": "module"
  2. 使用
    import
    export
    语法。
  3. 使用
    node --experimental-modules
    命令运行程序。

例如:

// package.json
{
  "type": "module"
}
// main.mjs
import { myFunction } from './module.js';
myFunction();
node --experimental-modules main.mjs

虽然Node.js开始支持ES模块,但CommonJS仍然是Node.js中最常用的模块化方案。

如何在浏览器中使用CommonJS

浏览器原生不支持CommonJS。要使用CommonJS,需要使用打包工具(如Webpack、Parcel)将CommonJS模块转换为浏览器可以识别的格式。

打包工具会将CommonJS模块及其依赖打包成一个或多个JavaScript文件,然后在HTML文件中引入这些文件。这样就可以在浏览器中使用CommonJS模块了。

未来趋势

随着ES模块的普及,它将逐渐取代CommonJS成为JavaScript中最主要的模块化方案。ES模块具有更好的性能、更可靠的循环依赖处理方式和更灵活的语法。Node.js对ES模块的支持也越来越完善,这使得ES模块在服务器端JavaScript环境中也越来越受欢迎。

相关专题

更多
js获取数组长度的方法
js获取数组长度的方法

在js中,可以利用array对象的length属性来获取数组长度,该属性可设置或返回数组中元素的数目,只需要使用“array.length”语句即可返回表示数组对象的元素个数的数值,也就是长度值。php中文网还提供JavaScript数组的相关下载、相关课程等内容,供大家免费下载使用。

536

2023.06.20

js刷新当前页面
js刷新当前页面

js刷新当前页面的方法:1、reload方法,该方法强迫浏览器刷新当前页面,语法为“location.reload([bForceGet]) ”;2、replace方法,该方法通过指定URL替换当前缓存在历史里(客户端)的项目,因此当使用replace方法之后,不能通过“前进”和“后退”来访问已经被替换的URL,语法为“location.replace(URL) ”。php中文网为大家带来了js刷新当前页面的相关知识、以及相关文章等内容

372

2023.07.04

js四舍五入
js四舍五入

js四舍五入的方法:1、tofixed方法,可把 Number 四舍五入为指定小数位数的数字;2、round() 方法,可把一个数字舍入为最接近的整数。php中文网为大家带来了js四舍五入的相关知识、以及相关文章等内容

706

2023.07.04

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

470

2023.09.01

JavaScript转义字符
JavaScript转义字符

JavaScript中的转义字符是反斜杠和引号,可以在字符串中表示特殊字符或改变字符的含义。本专题为大家提供转义字符相关的文章、下载、课程内容,供大家免费下载体验。

388

2023.09.04

js生成随机数的方法
js生成随机数的方法

js生成随机数的方法有:1、使用random函数生成0-1之间的随机数;2、使用random函数和特定范围来生成随机整数;3、使用random函数和round函数生成0-99之间的随机整数;4、使用random函数和其他函数生成更复杂的随机数;5、使用random函数和其他函数生成范围内的随机小数;6、使用random函数和其他函数生成范围内的随机整数或小数。

989

2023.09.04

如何启用JavaScript
如何启用JavaScript

JavaScript启用方法有内联脚本、内部脚本、外部脚本和异步加载。详细介绍:1、内联脚本是将JavaScript代码直接嵌入到HTML标签中;2、内部脚本是将JavaScript代码放置在HTML文件的`<script>`标签中;3、外部脚本是将JavaScript代码放置在一个独立的文件;4、外部脚本是将JavaScript代码放置在一个独立的文件。

652

2023.09.12

Js中Symbol类详解
Js中Symbol类详解

javascript中的Symbol数据类型是一种基本数据类型,用于表示独一无二的值。Symbol的特点:1、独一无二,每个Symbol值都是唯一的,不会与其他任何值相等;2、不可变性,Symbol值一旦创建,就不能修改或者重新赋值;3、隐藏性,Symbol值不会被隐式转换为其他类型;4、无法枚举,Symbol值作为对象的属性名时,默认是不可枚举的。

535

2023.09.20

苹果官网入口直接访问
苹果官网入口直接访问

苹果官网直接访问入口是https://www.apple.com/cn/,该页面具备0.8秒首屏渲染、HTTP/3与Brotli加速、WebP+AVIF双格式图片、免登录浏览全参数等特性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

10

2025.12.24

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最经典的Node.JS全套视频教程
最经典的Node.JS全套视频教程

共20课时 | 2.6万人学习

JavaScript模块化教程
JavaScript模块化教程

共10课时 | 1万人学习

【web前端】Node.js快速入门
【web前端】Node.js快速入门

共16课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号