就在刚4个小时前,TC39将以下特性加入到了 ES2019 中。让我们来看看这些新的特性给我们带来了什么样的改变。

喜大普奔,es2019登场_json

ES2019 新特性:

➡️ Array#{flat,flatMap}

➡️ Object.fromEntries

➡️ String#{trimStart,trimEnd}

➡️ Symbol#description

➡️ try { } catch {} // optional binding

➡️ JSON ⊂ ECMAScript

➡️ well-formed JSON.stringify

➡️ stable Array#sort

➡️ revised Function#toString

JSON ⊂ ECMAScript (JSON superset)

行分隔符(U + 2028)和段分隔符(U + 2029)符号现在允许在字符串文字中,与JSON匹配。 以前,这些符号在字符串文字中被视为行终止符,因此使用它们会导致SyntaxError异常。

well-formed JSON.stringify

更加友好的 JSON.stringify (修复了对于一些超出范围的 unicode 展示错误的问题。)

如果输入 Unicode 格式但是超出范围的字符,在原先JSON.stringify返回格式错误的Unicode字符串:

现在实现了一个改变JSON.stringify的第3阶段提案,因此它为其输出转义序列,使其成为有效Unicode(并以UTF-8表示):

stable Array#sort

在以前,sort 函数中,10个以上元素的数组 V8 使用不稳定的QuickSort(快排。现在,使用稳定的TimSort算法。)

TimSort算法: https://en.wikipedia.org/wiki/Timsort

revised Function#toString

Function.prototype.toString()现在返回精确字符,包括空格和注释。原先和现在的比较:

Array #{flat, flatMap}

数组降维,递归地将数组展平到指定的深度,默认为1。

Object.fromEntries

Object.fromEntries(Object.entries(object))≈ 对象

它类似于Lodash的_.fromPairs。

喜大普奔,es2019登场_字符串_02

String#{trimStart,trimEnd}

前后的空白符可以指定一边去除。

Symbol.prototype.description

通过工厂函数Symbol()创建符号时,您可以选择通过参数提供字符串作为描述:

以前,访问描述的唯一方法是将符号转换为字符串:

现在引入了getter Symbol.prototype.description以直接访问描述:

try {} catch {}

现在try {} catch {} 有了更加简便的方法,变成了可选型。

在以前

现在

喜大普奔,es2019登场_ico_03

更多提案:

https://github.com/tc39/proposals/blob/master/finished-proposals.md




喜大普奔,es2019登场_json_04


长按二维码,可以关注我哟