Node.js 21版本正式发布

发表时间: 2023-10-19 08:30

Node官方宣布发布Node.js 21新版本。其亮点包括V8 JS引擎11.8、稳定的 fetch和WebStreams,一个新的实验标志来翻转模块默认值(
--experimental-default-type), 内置的WebSocket客户端、测试运行程序等更新,请和虫虫一起来学习一下。

概述

Node.js 21在多个领域取得进展,许多新功能和修复已融入到现有的LTS版本中。

随着Node 21的发布,顺次Node.js 20将发布长期支持(LTS)版本,Node.js 21将取代 Node.js 20为 “Current”版本。根据发布时间表,Node.js 21将在接下来的半年内为“Current”版本(直到2024年4月)。

请通过Node官方下载频道要下载Node.js 21.0.0:

功能变化

稳定的fetch/WebStreams

Node 21最新更新包括fetch模块和WebStreams。更新后,这两个模块在稳定性和性能增强,一个getch模块的示例如下:

内置WebSocket客户端

最新版本中将推出实验性浏览器兼容WebSocke。新功能需要通过--experimental-websocket选项启动:

node --experimental-websocket index.js

V8引擎

与往常一样,Node.js中包含了新版本的V8引擎,更新至版本11.8。

新版本带来了改进的性能和新的语言功能,包括:

数组分组:该功能可以更有效地组织和操作数组,从而增强数据处理能力。


ArrayBuffer.prototype.transfer
:提供给开发人员的一个强大的工具,可以在内存中进行高效的数据传输和管理。

WebAssembly扩展常量表达式:这一新增功能通过扩展WebAssembly的功能进一步增强了开发人员的能力,支持使用扩展常量表达式来增强代码执行。

测试运行程序中对glob的支持

在新版本中测试运行程序引入了对glob表达式的支持,可以通过指定—test参数指定范围。这样现在可以使用强大的glob模式更高效、更灵活地运行测试。 例如,可以使用以下命令跨多个目录扩展所有文件.test.js执行测试:

node --test **/*.test.js

覆盖模块默认值的标志--experimental-default-type

新选项
--experimental-default-type可用于覆盖Node.js使用的默认模块配置。 已明确定义为ES模块或CommonJS的输入,例如通过package.json,"type"范围或.mjs/.cjs文件扩展名或--input-type标志指定的,不受影响该选项影响。

而当前隐式的CommonJS将被解释为ES模块
--experimental-default-type=module:

如果--input-type未指定,通过提供的字符串输入--eval或 TDIN。

文件结尾为.js或者没有扩展名,如果没有package.json文件存在于同一文件夹或任何父文件夹中。

文件结尾为.js或没有扩展名,如果最近的父级package.json字段缺少一个 type范围; 除非该文件夹位于node_modules文件夹。

此外,如果满足以下条件,无扩展名文件将被解释为WebAssembly:
--experimental-wasm-modules被传递并且文件以WebAssembly 序言开头 --experimental-wasm-modules被传递并且文件以WebAssembly 序言开头 \0asm。asm。

globalPreload钩子被删除,用registe和initializ取代

模块定制钩子globalPreload已被删除,用register取代它用来将数据从应用程序线程发送到自定义挂钩,和initialize钩子在线程之间建立通信通道。

fs.writeFile刷新选项

写入文件时,数据可能不会立即刷新到永久存储,这允许后续读取操作可能会读取到陈旧数据。新版本添加了一个 'flush'的选项强制fs.writeFile函数在成功写入操作结束刷新将数据刷新到存储。

性能改善

性能是运行时的一个重要属性,新版本中在URL、fetch、streams、node:fs 和HTTP都有大幅度改善。

Node.js流团队不断优化可写和可读流。在新版本中,通过删除冗余检查来进一步优化流,利用位图,并以更有效的方式安排回调。

HTTP协议

以前,当写入分块响应时,Node.js 会为每次调用创建一个单独的块 .write(...)无论响应是否被塞住。 这会导致客户端和服务器端产生不必要的开销。

新版本中通过为所有调用创建单个块来修复此问题write(...)当打开响应时。

以下官方Transfer-Encoding文档的示例:

res.cork();res.write('Mozilla');res.write(' Developer Network');res.uncork();

每个块的开头,都需要以十六进制格式,并添加当前块的长度,然后后跟结束字符“\r\n”,然后是块本身,最后是另一个“\r\n”。终止块是常规块,但其长度为零。

产生响应流:

HTTP/1.1 200 OKContent-Type: text/plainTransfer-Encoding: chunked7\r\nMozilla\r\n18\r\nDeveloper Network\r\n0\r\n\r\n

新版本中绕过响应解锁响应时,所有内容都会合并为一个块。减少了很多不必要的开销。

HTTP/1.1 200 OKContent-Type: text/plainTransfer-Encoding: chunked25\r\nMozilla Developer Network\r\n0\r\n\r\n

llhttp 9.1.2 严格模式增强

在老版本的Node.js 中,默认情况下不会启用严格模式。在新版本中,严格模式中包含的所有设置均默认启用,从而增强了代码的可靠性和安全性。

在标题之后的\r\n现在是强制性。 此外,\r\n现在需要加在一个块之后,确保数据处理的一致性。

消息后的数据传输Connection:close标头被解析不再允许。这个极大增强了协议并改进了连接处理。

为了适应特定的用例,新增加了--insecure-http-parser标志。该选项允许用户禁用上述更改并保持与以前的解析行为的向后兼容性。

这些更新旨在增强整体系统稳定性并提高了Node.js应用程序中数据处理的一致性。建议开发人员检查其代码库,根据新的规范进行相应调整,以确保与最新版本的无缝集成。

navigator对象集成

在Node.js 21 中,引入了全局导航器对象,增强了Web互操作性。新版本中,开发者可以通过
navigator.hardwareConcurrency访问硬件并发信息。

总结

新的21版本不光在功能上提供了很多更新变化,而且在性能和安全上做了很大的改善。大家可以赶快更新尝鲜,并及时分享感受。

最后,Node.js 16 (LTS) 已停止支持,建议及时更新到更高的LTS版本(18或20)。