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

news2024/10/6 10:42:09

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

这种分歧围绕着 CommonJSES 模块,这是两个用于划分 JavaScript代码的主要系统。

理解这个分歧

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

现在,它不仅仅是一个浏览器的语言。它可以为服务器和其他应用程序提供动力。

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

出现的解决方案?一个叫做CommonJS的模块系统。

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

CommonJS 使用一个叫做 require 的函数,允许你从其他文件中提取 JavaScript并访问从它们导出的函数。

然而,JavaScript 很快用ES6——适应了这些想法,以满足Web应用程序的需求。他们引入了importexport

import moduleA from './moduleA';

现在,你可能会纳闷,为什么JavaScript没有坚持已经在使用的require调用呢?

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

因此,分裂开始了。

兼容性难题

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

如果你在ES模块内部运行,你可以没有问题地导入CommonJS。但是,使用CommonJS导入ES模块是不行的——除非你采用一个模拟导入的异步函数解决方法。

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

打包器的作用

像Babel或TypeScript这样的打包器或转译器为这个复杂问题增加了另一层,你写的内容取决于你发出的内容。你可以用ES模块写,但发出 CommonJS

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

如果你在构建的代码中看到 require调用,你就是在发出 CommonJS,而importexport的存在表示你是ES模块的未来的一部分。

未来属于ES模块

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

由于支持这些不同的模块系统,JavaScript工具链可能非常复杂。

采用ES模块,你正在简化Web开发。所有的Node.js长期支持版本现在都使用ES模块,这标志着一个明确的海变。

尽可能使用ES模块。现在是时候结束这种分裂,拥抱未来了。现代JavaScript,统一的JavaScript。

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

欢迎长按图片加刷碗智为好友,定时分享 Vue React Ts 等。

9524b43cce6b9be28546f07743d1295d.png

最后:

vue2与vue3技巧合集

VueUse源码解读

68b997442939fd6f51d3003692a3e37b.jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1191611.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

不用开会员就能在线编辑、管理及分享各类地理空间数据!

「四维轻云」作为一款地理空间数据云管理平台,具有三维模型、正射影像、激光点云、数字高程模型、人工模型和矢量数据等地理空间数据的在线管理、浏览及分享等功能,致力于为用户提供更加方便、快捷的地理空间数据解决方案。 一、发布、管理超大空间数据…

交易所开发搭建

在当今的数字货币市场中,交易所开发搭建已经成为了一个重要的领域。交易所是数字货币交易的主要场所,为投资者提供了安全、可靠、高效的交易服本务文。将详细介绍交易所开发搭建的整个流程,包括需求分析、设计、技术选型、开发、测试和上线等…

Yolov8模型训练报错:torch.cuda.OutOfMemoryError

最近在使用自己的数据训练Yolov8模型的时候遇到了很多错误,下面将逐一解答。 问题报错 在训练过程中红字报错:torch.cuda.OutOfMemoryError: CUDA out of memory. 后面还会跟着一大段报错: Tried to allocate XXX MiB (GPU 0; XXX GiB to…

epoll实现 IO复用

1、epoll实现 IO复用 epoll的提出--》它所支持的文件描述符上限是系统可以最大打开的文件的数目;eg:1GB机器上,这个上限10万个左右。 每个fd上面有callback(回调函数)函数,只有活跃的fd才有主动调用callback,不需要轮询…

国密算法SSL证书

国密算法,即国家商用密码算法,是中国政府推动的一项密码算法标准,目的是提高我国信息安全水平。这一标准覆盖了对称密码算法、非对称密码算法、哈希函数等多个方面。在SSL证书领域,国密算法的应用对于保障网络通信的安全至关重要。…

YB1205B S0T23开关式异步升压具恒压恒流LED驱动器

YB1205B S0T23开关式异步升压具恒压恒流LED驱动器 产品简介: YB1205B是一种输入电压范围宽(0.85.5V),可调恒定电流和限定电流两种模式来驱动白光LED而设计的升压型DCDC变换器。采用变频模式,逐周期限流,使输入输出电流随电源电压降低均匀变…

全局前置路由守卫(beforeEach)

全局前置路由守卫(beforeEach) 功能:每一次切换任意路由组件之前都会被调用,相当于在进入另一个路由组件之前设置一个权限。 路由守卫的存在意义就是在不同的时间,不同的位置,去添加代码。如:J…

招聘信息采集

首先&#xff0c;我们需要使用PHP的curl库来发送HTTP请求。以下是一个基本的示例&#xff1a; <?php // 初始化curl $ch curl_init();// 设置代理 curl_setopt($ch, CURLOPT_PROXY, "jshk.com.cn");// 设置URL curl_setopt($ch, CURLOPT_URL, "http://www…

echarts图从隐藏到显示以后大小有问题的解决方法

大家好&#xff0c;我是南宫。 今天分享一个刚刚解决的问题。 稍微介绍一下问题的背景&#xff1a; 我有一个绘制柱状图的需求&#xff0c;之前已经画好了&#xff0c;没想到今天对接数据的时候发现&#xff0c;如果没有数据&#xff0c;后端是直接返回一个空数组的。&#…

面向对象高级

本期对应知识库&#xff1a;&#xff08;持续更新中&#xff01;&#xff09; 面向对象高级 (yuque.com) ​​​​​​​尚硅谷_宋红康_对象内存解析.pptx static 适用于公用变量 开发中&#xff0c;变量 经常把一些常量设置为静态static 例如 PI 方法 经常把工具类中的方…

RapidSSL证书

RapidSSL是一家经验丰富的证书颁发机构&#xff0c;主要专注于提供标准和通配符SSL证书的域验证SSL证书。在2017年被DigicertCA收购后&#xff0c;RapidSSL改进了技术并开始使用现代基础设施。专注于为小型企业和网站提供基本安全解决方案的SSL加密。RapidSSL它具有强大的浏览器…

股票四倍杠杆什么意思?

股票四倍杠杆是指投资者通过借款或使用金融衍生品&#xff0c;以增加其投资股票的能力&#xff0c;达到放大投资回报的目的。具体来说&#xff0c;投资者可以通过向券商或银行等金融机构借入资金&#xff0c;或者使用融资融券等金融衍生品&#xff0c;以增加其购买股票的资本&a…

SAM + 用于文本到图像修复的稳定扩散

推荐基于稳定扩散(stable diffusion) AI 模型开发的自动纹理工具&#xff1a; DreamTexture.js自动纹理化开发包 - NSDT 什么是SAM&#xff1f; 今年早些时候&#xff0c;Meta AI 发布了新的开源项目&#xff1a;Segment Anything Model &#xff08;SAM&#xff09;&#xff…

智慧工地建筑施工项目管理平台源码,实现人员劳务实名制管理、区域安防监控、智能AI识别、用电/水监控、噪音扬尘监测、现场物料管理等功能

智慧工地管理系统源码&#xff0c;智慧工地云平台源码&#xff0c;PC端APP端源码 智慧工地管理平台实现对人员劳务实名制管理、施工进度、安全管理、设备管理、区域安防监控系统、智能AI识别系统、用电/水监控系统、噪音扬尘监测、现场物料管理系统等方面的实时监控和管理&…

使用U盘安装ubuntu22操作教程

U盘启动 将烧录好的U盘&#xff0c;插上待安装系统的电脑 服务器在开机之后长按【ESC键】进入BIOS选项中&#xff0c;选择对应的U盘启动 如下图&#xff0c;在界面中“USB”选项就是我的U盘&#xff0c;第一启动项选择U盘启动&#xff0c;其他启动项不动&#xff0c;选择后按F…

【计算思维题】少儿编程 蓝桥杯省赛考试计算思维真题 数学逻辑思维真题详细解析第11套

少儿编程 蓝桥杯青少组计算思维真题及解析 第十四届蓝桥杯省赛真题 1、晶晶在注册一个学习网站时,需要设置密码。网站提示: 密码必须由 8~16个字符组成,可以包合数字、大写字母、小写字母、特殊符号这 4种字符类型。 包含4种不同类型字符的密码是强密码; 包含2种或3种不…

软件开发项目文档系列之十五如何撰写项目结项报告

这是一个项目总结文档的说明文件&#xff0c;它提供了项目的概述、建设情况、技术情况、测试情况、培训情况、试运行情况、主要成效等详细信息。 1 项目概述 项目名称&#xff1a;明确指定了项目的名称&#xff0c;这有助于确保文件的清晰性和易读性。 项目相关单位&#xff…

「Java开发指南」如何用MyEclipse搭建Spring MVC应用程序?(二)

本教程将指导开发者如何生成一个可运行的Spring MVC客户应用程序&#xff0c;该应用程序实现域模型的CRUD应用程序模式。在本教程中&#xff0c;您将学习如何&#xff1a; 从数据库表的Scaffold到现有项目部署搭建的应用程序 使用Spring MVC搭建需要MyEclipse Spring或Bling授…

三相电机的某些实测特性曲线

三相电机参数&#xff1a; 0.75KW&#xff0c;额定电流是2A&#xff0c;功率因数0.71&#xff0c;效率78.9%。制式S1. 1.负载不变时的线电压与线电流的关系 1.1相关数据与python代码&#xff1a; 这里记录了一系列的实验&#xff1a; 第一组实验&#xff1a;近乎空载&#xf…

HTTParty库数据抓取代码示例

使用HTTParty库的网络爬虫程序&#xff0c; ruby require httparty # 设置服务器 proxy_host proxy_port # 使用HTTParty库发送HTTP请求获取网页内容 response HTTParty.get(/, :proxy > { :host > proxy_host, :port > proxy_port }) # 打印获取的网页内容 …