溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ES10的13個新特性示例(小結)

發(fā)布時間:2020-10-05 13:24:52 來源:腳本之家 閱讀:147 作者:前端知否 欄目:web開發(fā)

ES10的13個新特性示例(小結)

介紹

ES10是與2019年相對應的ECMAScript版本。這個版本中的新功能沒有ES6(2015)中的那么多。但是,也不乏一些有用的功能。

本文在簡單的代碼示例中介紹了ES10提供的功能。這樣,您無需復雜的解釋即可快速了解新功能。

當然,需要具備JavaScript的基礎知識才能完全理解所介紹的新功能。

ES2019中的JavaScript新功能包括:

  • Array#{flat,flatMap}
  • Object.fromEntries
  • String#{trimStart,trimEnd}
  • Symbol#description
  • try { } catch {} // 可選的錯誤參數綁定
  • JSON ⊂ ECMAScript
  • 格式良好的 JSON.stringify
  • 穩(wěn)定的排序 Array#sort
  • 新版 Function#toString
  • 新增 BigInt 原始類型 (stage 3).
  • 動態(tài)引入模塊(stage 3).
  • 標準的 globalThis 對象 (stage 3).
  • ES10 Class: private, static & public (stage 3).

Array.flat() & Array.flatMap()

兩個新的數組方法:

Array.flat() 方法創(chuàng)建一個新數組,所有子數組元素都以遞歸方式合并到該數組中,直至達到指定深度。

Array.flatMap() 方法首先使用map函數轉換每個元素,然后將結果展平為新數組。它與map()后再調用深度為1的flat() 效果相同,但是flatMap()將兩者合并為一種方法,效率更高。

ES10的13個新特性示例(小結)

Object.fromEntries()

把鍵值對數組為元素的二維數組轉換為一個對象。

ES10的13個新特性示例(小結)

String.protype.matchAll()

matchAll() 方法返回所有與正則表達式匹配字符串的結果的迭代器,包括捕獲組。

ES10的13個新特性示例(小結)

String.trimStart() & String.trimEnd()

有兩種新的String方法可從字符串中刪除空格:

trimStart() 方法從字符串的開頭刪除空格。
trimEnd() 方法從字符串末尾刪除空格。

ES10的13個新特性示例(小結)

Symbol.Description

當創(chuàng)建符號時,可以提供一個字符串作為描述。在ES10中,有一個獲取描述的訪問器。

ES10的13個新特性示例(小結)

可選的 Catch 參數變量

過去,try / catch語句中的catch子句需要一個變量?,F(xiàn)在,它允許開發(fā)人員使用try / catch而不創(chuàng)建未使用的error變量綁定。

ES10的13個新特性示例(小結)

JSON⊂ECMAScript

在ES10之前的版本中,不接受非轉義的行分隔符U+2028和段落分隔符U+2029。

U+2028是段落分隔符。
U+2029是行分隔符。

ES10的13個新特性示例(小結)

格式良好的 JSON.stringify()

JSON.stringify() 可能返回U+D800和U+DFFF之間的字符,來作為沒有等效UTF-8字符的值。但是,JSON格式需要UTF-8編碼。解決方案是,將未配對的替代代碼點表示為JSON轉義序列,而不是將其作為單個UTF-16代碼單元返回。

ES10的13個新特性示例(小結)

Array.prototype.sort()

V8的先前實現(xiàn),對包含10個以上項的數組使用了不穩(wěn)定的快速排序算法。

一種穩(wěn)定的排序算法是,當兩個具有相同鍵的對象在排序輸出中出現(xiàn)的順序,與未排序輸入中出現(xiàn)的順序相同。

ES10的13個新特性示例(小結)

新版 Function.toString()

toString() 方法返回一個表示函數源代碼的字符串。在ES6中,當在函數上調用toString時,它將根據ECMAScript引擎返回該函數的字符串表示形式。如果可能,它將返回源代碼,否則-一個標準化的占位符。

ES10的13個新特性示例(小結)

BigInt — 任意精度的整數

BigInt是第7個原始類型,它是一個任意精度的整數。而不僅僅是在9007199254740992處的最大值。

ES10的13個新特性示例(小結)

動態(tài)引入

動態(tài)import()返回所請求模塊的Promise。因此,可以使用async/await 將導入的模塊分配給變量。

ES10的13個新特性示例(小結)

ES10的13個新特性示例(小結)

標準 globalThis 對象

全局 this 在ES10之前尚未標準化。在生產代碼中,您可以通過編寫下邊代碼來“標準化”它:

ES10的13個新特性示例(小結)

ES10 Class: private, static & public 成員變量,函數

現(xiàn)在,新的語法字符#(哈希標簽)用于直接在類中定義變量,函數,getter和setter,以及構造函數和類方法。

ES10的13個新特性示例(小結)

總結

自2015年ES6出現(xiàn)以來,這個語言就一直處于高速發(fā)展的狀態(tài)。在這篇文章中,我們回顧了ES10(2019)中出現(xiàn)的功能,并介紹了一些在ES11(2020)中將保持穩(wěn)定的功能,因為它們處于狀態(tài)3,并且可能最終會在下一版中實現(xiàn)標準化。

盡管這些功能中的許多功能對于Web應用程序的開發(fā)可能不是必需的,但是它們提供了通過技巧或大量冗長代碼才能實現(xiàn)的可能性。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI