英文 | https ://medium.com/@nodejs/node-js-v15-0-0-is-here-deb00750f278
前两天,Node.js官方发布了Node.js 15的正式版本,Node.js 15将替代Node.js 14成为当前的稳定发行版,且将在本月晚些时候升级为LTS(长期支持)版本。如果大家想体验下Node.js 15的最新功能,可以从官方进行下载。
那节点。js 15带来了一些新的功能和特性呢?主要体现在以下几个方面:
- 中止控制器
- N-API版本7
- npm 7
- 未处理的拒绝默认值
- QUIC
- V8 8.6
1、中止控制器
AbortController接口表示一个控制器对象,允许开发者根据需要中止一个或多个Web请求,Node。
js 15加入了AbortController的一个实验性实现。
AbortController是一个分布式实用工具类,可根据AbortController Web API在基于更改的Promise的API中取消发出的请求信号,如下所示。
const ac = new AbortController();
ac.signal.addEventListener('abort', () => console.log('Aborted!'),
{ once: true });
ac.abort();
console.log(ac.signal.aborted); //Prints True
在上面的示例中,当调用abortController.abort()方法时就会发出中断事件,同时,AbortController将仅触发一次中断事件。同时,附加到AbortSignal上的事件侦听器应使用{或等效于EventEmitterAPI的一次()),以确保重新终止事件得到处理,然后再将事件侦听器删除。
关于AbortController的Node.js API文档,可以参考:AbortController。
2、N-API 7
N-API是一个用于内置本机插件的API,它独立于且之上JavaScript运行时环境(如V8),并作为Node.js本身的一部分。
此API将作为跨Node.js版本已编译的应用程序它是为了将插件和替换JavaScript引擎的插入隔离开来,并且允许在一个版本编译的模块中不需要重新编译就可以在更高版本的Node.js上运行。
N-API是一个C语言的API,它确保了Node.js版本和不同编译器级别之间的应用程序接口(ABI)的稳定性。C++ API可以更容易使用。
为了支持使用C ++,Node.js使用了一个C ++包装器模块称为node-addon-api,此包装器提供了一个可内联的C ++ API。
使用node-addon-api生成的二进制文件将依赖于Node.js导出的基于C函数符号的N -API接口,node-addon-api是一种更有效的编写代码的方法,用来编写调用N-API。
关于Node.js的N-API,可以参考:带有N-API的C / C ++插件
下面是node-addon-api的一个使用示例。
Object obj = Object::New(env);
obj["foo"] = String::New(env, "bar");
napi_status status;
napi_value object, string;
status = napi_create_object(env, &object);
if (status != napi_ok) {
napi_throw_error(env, ...);
return;
}
status = napi_create_string_utf8(env, "bar", NAPI_AUTO_LENGTH, &string);
if (status != napi_ok) {
napi_throw_error(env, ...);
return;
}
status = napi_set_named_property(env, object, "foo", string);
if (status != napi_ok) {
napi_throw_error(env, ...);
return;
}
此次更新的N-API 7是上一个大版本以来的第一个新版本,带来了ArrayBuffers的相关内容。
3、npm 7
Node.js 15附带了npm的新大版本npm7。npm7有很多新功能,包括npm工作区和新的package-lock.json格式。npm7还包括yarn.lock文件支持。npm7的一大堆变化是默认安装对等依赖项。
4、未处理的拒绝默认值
从Node.js 15开始,unhandledRejection的默认状态已更改为throw(以前是warn)。
在throw模式下,如果未设置unhandledRejection hook,则将unhandledRejection升级为未捕获的异常。
会看到任何行为变化,并且仍然可以使用--unhandled-rejections = mode进度标志来切换模式。
Node.js之前的多个版本都会发出UnhandledPromiseRejectionWarning,而根据《 Node.js用户见解:Unhandled Promise Rejections》调查的结果,Node.js TSC同意将模式切换为throw。
5、QUIC
QUIC是谷歌制定的一种基于UDP的低时延的互联网传输层协议,它是HTTP / 3的基础传输协议。
并且,在2016年11月国际互联网工程任务组(IETF)提出了第一次QUIC工作组会议,受到了业界的广泛关注,意味着QUIC开始在成为新一代传输层协议上迈出了关键的一步。
同时,QUIC具有内置的TLS 1.3安全性,流控制,错误纠正,连接迁移和多路互补。
Node.js 15附带QUIC的实验性支持,可通过--experimental-quic配置标志编译Node.js来启用。例如,核心网模块公开了Node.js QUIC实现,代码如下。
const { createQuicSocket } = require('net');
'use strict';
const key = getTLSKeySomehow();
const cert = getTLSCertSomehow();
const { createQuicSocket } = require('net');
// Create the QUIC UDP IPv4 socket bound to local IP port 1234
const socket = createQuicSocket({ endpoint: { port: 1234 } });
socket.on('session', async (session) => {
// A new server side session has been created!
// The peer opened a new stream!
session.on('stream', (stream) => {
// Let's say hello
stream.end('Hello World');
// Let's see what the peer has to say...
stream.setEncoding('utf8');
stream.on('data', console.log);
stream.on('end', () => console.log('stream ended'));
});
const uni = await session.openStream({ halfOpen: true });
uni.write('hi ');
uni.end('from the server!');
});
// Tell the socket to operate as a server using the given
// key and certificate to secure new connections, using
// the fictional 'hello' application protocol.
(async function() {
await socket.listen({ key, cert, alpn: 'hello' });
console.log('The socket is listening for sessions!');
})();
关于QUIC的更多信息,可以参考下面的文档:QUIC。
6、V8 8.6
V8 JavaScript引擎已更新为V8 8.6(V8 8.4是Node.js 14中的最新版本)。除了性能调整和改进之外,V8更新还带来了以下语言特性:
Promise.any()-MDN
Promise.any()接收一个Promise可重复对象,只要其中的一个诺言成功,就返回那个已经成功的诺言。如果可继承对象中没有一个诺言成功(即所有的诺言都失败/拒绝),就返回一个失败的promise和AggregateError类型的实例,它是Error的一个子类,用于把单个的错误集合在一起。
Promise.any()的参考文档如下所示:Promise.any()
AggregateError——MDN
AggregateError主要用于操作报告多个错误被抛出的场景,语法格式如下:
new AggregateError(errors[, message])
捕获一个AggregateError的示例代码如下:
Promise.any([
Promise.reject(new Error("some error")),
]).catch(e => {
console.log(e instanceof AggregateError); // true
console.log(e.message); // "All Promises rejected"
console.log(e.name); // "AggregateError"
console.log(e.errors); // [ Error: "some error" ]
});
创建一个AggregateError的示例代码如下:
try {
throw new AggregateError([
new Error("some error"),
], 'Hello');
} catch (e) {
console.log(e instanceof AggregateError); // true
console.log(e.message); // "Hello"
console.log(e.name); // "AggregateError"
console.log(e.errors); // [ Error: "some error" ]
}
详细参考文档:AggregateError
String.prototype.replaceAll()-MDN
replaceAll()方法是返回一个新字符串,新字符串所有满足pattern的部分都已被替换。pattern可以是一个字符串或一个RegExp,replace可以是一个字符串或一个在每次匹配被调用的函数。
const p = 'The quick brown fox jumps over the lazy dog. If the dog reacted, was it really lazy?';
const regex = /dog/gi;
console.log(p.replaceAll(regex, 'ferret'));
// expected output: "The quick brown fox jumps over the lazy ferret. If the ferret reacted, was it really lazy?"
console.log(p.replaceAll('dog', 'monkey'));
// expected output: "The quick brown fox jumps over the lazy monkey. If the monkey reacted, was it really lazy?"
详细内容参考:String.prototype.replaceAll()
升级
另外,通过Node.js 15新版本的发布!官方希望开发者尽快进行进行升级,互换遇到的问题反馈就给官方,。当然,开发者还可以使用Node.js 15测试你的应用程序和模块,以确保您的项目与最新的Node.js特性和更改兼容。
并且,Node.js官方也开始计划升级到Node.js 14,进入在下周升级到LTS,支持会持续到直到2023年4月。还要注意的是,Node.js 10到2021年4月结束生命周期。因此,如果你仍在使用Node.js 10,我们建议你开始计划升级。