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

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

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

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

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

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

理解这个分歧

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

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

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

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

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

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

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

import moduleA from './moduleA';

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

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

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

兼容性难题

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

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

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

打包器的作用

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

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

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

未来属于ES模块

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

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

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

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

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

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

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

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

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

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

标签:
  • 热门焦点
  • 掘力计划第 20 期:Flutter 混合开发的混乱之治

    在掘力计划系列活动第20场,《Flutter 开发实战详解》作者,掘金优秀作者,Github GSY 系列目负责人恋猫的小郭分享了Flutter 混合开发的混乱之治。Flutter 基于自研的 Skia 引擎
  • 一文看懂为苹果Vision Pro开发应用程序

    译者 | 布加迪审校 | 重楼苹果的Vision Pro是一款混合现实(MR)头戴设备。Vision Pro结合了虚拟现实(VR)和增强现实(AR)的沉浸感。其高分辨率显示屏、先进的传感器和强大的处理能力
  • Java NIO内存映射文件:提高文件读写效率的优秀实践!

    Java的NIO库提供了内存映射文件的支持,它可以将文件映射到内存中,从而可以更快地读取和写入文件数据。本文将对Java内存映射文件进行详细的介绍和演示。内存映射文件概述内存
  • 微信语音大揭秘:为什么禁止转发?

    大家好,我是你们的小米。今天,我要和大家聊一个有趣的话题:为什么微信语音不可以转发?这是一个我们经常在日常使用中遇到的问题,也是一个让很多人好奇的问题。让我们一起来揭开这
  • 使用LLM插件从命令行访问Llama 2

    最近的一个大新闻是Meta AI推出了新的开源授权的大型语言模型Llama 2。这是一项非常重要的进展:Llama 2可免费用于研究和商业用途。(几小时前,swyy发现它已从LLaMA 2更名为Lla
  • 这款新兴工具平台,让你的电脑效率翻倍

    随着信息技术的发展,我们获取信息的渠道越来越多,但是处理信息的效率却成为一个瓶颈。于是各种工具应运而生,都在争相解决我们的工作效率问题。今天我要给大家介绍一款效率
  • 苹果、三星、惠普等暂停向印度出口笔记本和平板电脑

    集微网消息,据彭博社报道,在8月3日印度突然禁止在没有许可证的情况下向印度进口电脑/平板及显示器等产品后,苹果、三星电子和惠普等大公司暂停向印度
  • OPPO K11搭载长寿版100W超级闪充:26分钟充满100%

    据此前官方宣布,OPPO将于7月25日也就是今天下午14:30举办新品发布会,届时全新的OPPO K11将正式与大家见面,将主打旗舰影像,和同档位竞品相比,其最大的卖
  • 利用职权私自解除被封帐号 Meta开除20多名员工

    11月18日消息,据外媒援引知情人士表示,过去一年时间内,Facebook母公司Meta解雇或处罚了20多名员工以及合同工,指控这些人通过内部系统以不当方式重置用户帐号,其
Top