当前位置:首页 > 科技  > 软件

JavaScript的大分水岭:CommonJS vs ES模块

来源: 责编: 时间:2023-11-08 09:10:29 313观看
导读所周知,JavaScript社区喜欢进行热烈的辩论。四年来,我们如何组织代码的问题上一直存在一个分歧——这是一个基本但令人意外地有争议的问题,继续将开发者分开。这种分歧围绕着 CommonJS 和 ES 模块,这是两个用于划分 JavaS

bhW28资讯网——每日最新资讯28at.com

所周知,JavaScript社区喜欢进行热烈的辩论。四年来,我们如何组织代码的问题上一直存在一个分歧——这是一个基本但令人意外地有争议的问题,继续将开发者分开。bhW28资讯网——每日最新资讯28at.com

这种分歧围绕着 CommonJS 和 ES 模块,这是两个用于划分 JavaScript代码的主要系统。bhW28资讯网——每日最新资讯28at.com

理解这个分歧

当JavaScript最初被发明时,它的主要角色是作为Web浏览器的脚本语言。但是,随着Node.js的出现,似乎展现出了一系列的可能性。bhW28资讯网——每日最新资讯28at.com

现在,它不仅仅是一个浏览器的语言。它可以为服务器和其他应用程序提供动力。bhW28资讯网——每日最新资讯28at.com

在那种情境下,浏览器中的所有东西都在全局作用域中,你不必过多地考虑模块。但是构建一个复杂的服务器应用程序并不那么简单。你不能把所有的代码都打包在一个文件中——那将是一个噩梦。bhW28资讯网——每日最新资讯28at.com

出现的解决方案?一个叫做CommonJS的模块系统。bhW28资讯网——每日最新资讯28at.com

const moduleA = require('./moduleA');

CommonJS 使用一个叫做 require 的函数,允许你从其他文件中提取 JavaScript并访问从它们导出的函数。bhW28资讯网——每日最新资讯28at.com

然而,JavaScript 很快用ES6——适应了这些想法,以满足Web应用程序的需求。他们引入了import和export。bhW28资讯网——每日最新资讯28at.com

import moduleA from './moduleA';

现在,你可能会纳闷,为什么JavaScript没有坚持已经在使用的require调用呢?bhW28资讯网——每日最新资讯28at.com

require 的问题在于它是同步的,并假设所有文件都已经准备好。但是,在浏览器上下文中,你可能需要等待外部资源时,require的同步性质会让系统崩溃。bhW28资讯网——每日最新资讯28at.com

因此,分裂开始了。bhW28资讯网——每日最新资讯28at.com

兼容性难题

大多数开发者转向ES模块,因为它们不仅是新颖的,而且很有趣。但一个相当大的群体仍然坚持使用CommonJS。这种分裂导致了兼容性问题。bhW28资讯网——每日最新资讯28at.com

如果你在ES模块内部运行,你可以没有问题地导入CommonJS。但是,使用CommonJS导入ES模块是不行的——除非你采用一个模拟导入的异步函数解决方法。bhW28资讯网——每日最新资讯28at.com

const moduleA = await import('./moduleA');

打包器的作用

像Babel或TypeScript这样的打包器或转译器为这个复杂问题增加了另一层,你写的内容取决于你发出的内容。你可以用ES模块写,但发出 CommonJS。bhW28资讯网——每日最新资讯28at.com

// Babel或TypeScript编译器将ES模块转换为CommonJSconst moduleA = require('./moduleA');

如果你在构建的代码中看到 require调用,你就是在发出 CommonJS,而import和export的存在表示你是ES模块的未来的一部分。bhW28资讯网——每日最新资讯28at.com

未来属于ES模块

在吸引了开发者注意的新工具中,bun 是亮点。bun 的主要亮点在于,它已经解决了CommonJS 和 ES 模块之间的互操作性问题。但是,这个修复并不完全符合规范——他们只是为了让它工作而修补了CommonJS和ES模块之间的问题。bhW28资讯网——每日最新资讯28at.com

由于支持这些不同的模块系统,JavaScript工具链可能非常复杂。bhW28资讯网——每日最新资讯28at.com

采用ES模块,你正在简化Web开发。所有的Node.js长期支持版本现在都使用ES模块,这标志着一个明确的海变。bhW28资讯网——每日最新资讯28at.com

尽可能使用ES模块。现在是时候结束这种分裂,拥抱未来了。现代JavaScript,统一的JavaScript。bhW28资讯网——每日最新资讯28at.com

如果你一直在使用或考虑使用 CommonJS,可能是时候仔细看看你的代码了。未来是一个有ES模块的地方,我们每个人都有责任使 JavaScript 的景观变得更加简单和有趣。bhW28资讯网——每日最新资讯28at.com

bhW28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-17641-0.htmlJavaScript的大分水岭:CommonJS vs ES模块

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 探索人工智能的世界:构建智能问答系统之前置篇

下一篇: 必读!SpringBoot接口参数校验N种实用技巧大揭秘

标签:
  • 热门焦点
  • 5月安卓手机好评榜:魅族20 Pro夺冠

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年5月1日至5月31日,仅限国内市场。第一名:魅族20 Pro好评率:97.50%不得不感慨魅族老品牌还
  • 线程通讯的三种方法!通俗易懂

    线程通信是指多个线程之间通过某种机制进行协调和交互,例如,线程等待和通知机制就是线程通讯的主要手段之一。 在 Java 中,线程等待和通知的实现手段有以下几种方式:Object 类下
  • 企业采用CRM系统的11个好处

    客户关系管理(CRM)软件可以为企业提供很多的好处,从客户保留到提高生产力。  CRM软件用于企业收集客户互动,以改善客户体验和满意度。  CRM软件市场规模如今超过580
  • Flowable工作流引擎的科普与实践

    一.引言当我们在日常工作和业务中需要进行各种审批流程时,可能会面临一系列技术和业务上的挑战。手动处理这些审批流程可能会导致开发成本的增加以及业务复杂度的上升。在这
  • 学习JavaScript的10个理由...

    作者 | Simplilearn编译 | 王瑞平当你决心学习一门语言的时候,很难选择到底应该学习哪一门,常用的语言有Python、Java、JavaScript、C/CPP、PHP、Swift、C#、Ruby、Objective-
  • 雅柏威士忌多款单品价格大跌,泥煤顶流也不香了?

    来源 | 烈酒商业观察编 | 肖海林今年以来,威士忌市场开始出现了降温迹象,越来越多不断暴涨的网红威士忌也开始悄然回归市场理性。近日,LVMH集团旗下苏格兰威士忌品牌雅柏(Ardbeg
  • 华为Mate60标准版细节曝光:经典星环相机模组回归

    这段时间以来,关于华为新旗舰的爆料日渐密集。据此前多方爆料,今年华为将开始恢复一年双旗舰战略,除上半年推出的P60系列外,往年下半年的Mate系列也将
  • 三星Galaxy Z Fold5官方渲染图曝光:13.4mm折叠厚度依旧感人

    据官方此前宣布,三星将于7月26日在韩国首尔举办Unpacked活动,届时将带来带来包括Galaxy Buds 3、Galaxy Watch 6、Galaxy Tab S9、Galaxy Z Flip 5、
  • 世界人工智能大会国际日开幕式活动在世博展览馆开启

    30日上午,世界人工智能大会国际日开幕式活动在世博展览馆开启,聚集国际城市代表、重量级院士专家、国际创新企业代表,共同打造人工智能交流平台。上海市副市
Top