前兩天,Node.js官方發佈了Node.js 15的正式版本,Node.js 15 將替代 Node.js 14 成爲當前的的穩定發行版,後者將在本月晚些時候升級爲 LTS(長期支持)版本。若是你們想體驗下Node.js 15 的最新功能,能夠從官方進行下載。javascript
那Node.js 15帶來了哪些新的功能和特性呢?主要體如今如下幾個方面:html
AbortController接口表示一個控制器對象,容許開發者根據須要停止一個或多個 Web請求,Node.js 15 加入了 AbortController 的一個實驗性實現。AbortController 是一個全局實用工具類,可根據 AbortController Web API在選定的基於 Promise 的 API 中取消發出的請求信號,以下所示。java
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 事件獲得處理,而後再將事件偵聽器刪除。node
關於AbortController的 Node.js API 文檔,能夠參考:AbortController。react
N-API是一個用於構建本機插件的API,它獨立於底層JavaScript運行時環境(如V8),並做爲Node.js自己的一部分。此API將做爲跨Node.js版本已編譯的應用程序接口(Application Binary Interface)的穩定版,簡稱(ABI)。它是爲了將Addons插件和底層JavaScript引擎的改動隔離開來,而且容許在一個版本編譯的模塊不須要從新編譯就能夠在更高版本的Node.js上運行。npm
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。json
關於 Node.js 的N-API,能夠參考:C/C++ addons with N-API api
下面是node-addon-api的一個使用例子。promise
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的相關內容。安全
Node.js 15 附帶了 npm 的新大版本 npm 7。npm 7 有許多新功能,包括 npm 工做區和新的 package-lock.json 格式。npm 7 還包括 yarn.lock 文件支持。npm 7 的一大變化是默認安裝對等依賴項。
從 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 是谷歌制定的一種基於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 JavaScript 引擎已更新爲 V8 8.6(V8 8.4 是 Node.js 14 中的最新版本)。除了性能調整和改進以外,V8 更新還帶來了如下語言特性:
Promise.any() 接收一個Promise可迭代對象,只要其中的一個 promise 成功,就返回那個已經成功的 promise 。若是可迭代對象中沒有一個 promise 成功(即全部的 promises 都失敗/拒絕),就返回一個失敗的 promise 和AggregateError類型的實例,它是 Error 的一個子類,用於把單一的錯誤集合在一塊兒。
Promise.any()的參考文檔以下所示:Promise.any()
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
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