首頁 >web前端 >js教程 >Node.js 15正式版發布,將替代Node.js 14成為目前的穩定發行版

Node.js 15正式版發布,將替代Node.js 14成為目前的穩定發行版

青灯夜游
青灯夜游轉載
2020-10-22 19:57:424434瀏覽

Node.js 15正式版發布,將替代Node.js 14成為目前的穩定發行版

前兩天,Node.js官方發布了Node.js 15的正式版本,Node.js 15 將替代Node.js 14 成為當前的穩定發行版,後者將在本月稍後升級為LTS(長期支援)版本。如果大家想體驗Node.js 15 的最新功能,可以從官方進行下載。

Node.js 15正式版發布,將替代Node.js 14成為目前的穩定發行版

影片教學推薦:nodejs 教學

那Node.js 15帶來了哪些新的功能和特性呢?主要體現在以下幾個方面:

  • AbortController
  • N-API 版本7
  • npm 7
  • unhandled rejections 預設拋出
  • QUIC
  • V8 8.6

AbortController

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()方法時就會發出 abort 事件,AbortController 將只觸發一次 abort 事件。同時,附加到AbortSignal 上的事件偵聽器應使用{ once: true}參數選項(或等效於EventEmitterAPI 的once()),以確保一旦abort 事件處理,然後再將事件偵聽器刪除。

關於AbortController的 Node.js API 文檔,可以參考:AbortController。

N-API 7

N-API是一個用於建立本機外掛程式的API,它獨立於底層JavaScript執行環境(如V8),並作為Node.js本身的一部分。此API將作為跨Node.js版本已編譯的應用程式介面(Application Binary Interface)的穩定版,簡稱(ABI)。它是為了將Addons插件和底層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,可以參考:C/C addons with N-API

下面是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的相關內容。

npm 7

Node.js 15 附帶了 npm 的新大版本 npm 7。 npm 7 有許多新功能,包括 npm 工作區和新的 package-lock.json 格式。 npm 7 也包括 yarn.lock 檔案支援。 npm 7 的一大變更是預設安裝對等依賴項。

unhandled rejections 預設拋出

從 Node.js 15 開始,unhandledRejection 的預設模式已變更為 throw(以前是 warn)。在 throw 模式下,如果未設定 unhandledRejection hook,則會將 unhandledRejection 提升為未捕獲的例外。擁有 unhandledRejection hook 的使用者應該不會看到任何行為變化,並且仍然可以使用 --unhandled-rejections=mode 進程標誌來切換模式。

Node.js 之前的多個版本都會預設發出 UnhandledPromiseRejectionWarning,而根據《Node.js 使用者見解:Unhandled Promise Rejections》調查的結果,Node.js TSC 同意將模式切換為 throw。

QUIC

QUIC 是Google制定的一種基於UDP的低時延的互聯網傳輸層協議,它是 HTTP/3 的基礎傳輸協議。並且,在2016年11月國際互聯網工程任務組(IETF)召開了第一次QUIC工作組會議,受到了業界的廣泛關注,意味著QUIC開始在成為新一代傳輸層協議上邁出了關鍵的一步。同時,QUIC 具有內建的 TLS 1.3 安全性、流控制、錯誤修正、連線遷移和多路復用。

Node.js 15 附帶 QUIC 的實驗性支持,可透過 --experimental-quic 配置標誌編譯 Node.js 來啟用。例如,核心 net 模組公開了 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 。

V8 8.6

V8 JavaScript 引擎已更新為 V8 8.6(V8 8.4 是 Node.js 14 中的最新版本)。除了效能調整和改進之外,V8 更新還帶來了以下語言特性:

Promise.any()——MDN

Promise.any() 接收一个Promise可迭代对象,只要其中的一个 promise 成功,就返回那个已经成功的 promise 。如果可迭代对象中没有一个 promise 成功(即所有的 promises 都失败/拒绝),就返回一个失败的 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 的部分都已被replacement 替换。pattern可以是一个字符串或一个 RegExp, replacement可以是一个字符串或一个在每次匹配被调用的函数。

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,我们建议你开始计划升级。

原文链接:https://medium.com/@nodejs/node-js-v15-0-0-is-here-deb00750f278

更多编程相关知识,请访问:编程入门!!

以上是Node.js 15正式版發布,將替代Node.js 14成為目前的穩定發行版的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除