2019年1月末的时候,ECMA TC39终于确定了ES2019版JavaScript的新增内容,ES2019 将会增加arrays, objects, strings, symbols, try/catch 和 JSON 等方面的特征。
Array#{flat,flatMap}
Array的原型链上增加了新的两个方法:Array.flat(tc39 proposal) 和 Array.flat(tc39 proposal) 能够进行扁平化多维数组:
var arr = [1, 2, 3, [4, 5, 6, [7, 8, 9, [10, 11, 12]]]]; |
等同于arr.flat(1)
arr.flat(1); // [1, 2, 3, 4, 5, 6, Array(4)] |
逐个展开:
arr.flat().flat() // [1, 2, 3, 4, 5, 6, 7, 8, 9, Array(3)] |
flatMap()
方法类似于数组的map
方法,对数组的每一项使用传入的function
,结果得到的是扁平化的数组,值得注意的是所有的结果将不会折叠,而是展示为一维数组:
var arr = [1, 2, 3, [4, 5, 6, [7, 8, 9, [10, 11, 12]]]]; |
BigInt
BigInt 是一个新的类型,用于表达大于 2^53 的值
Object.fromEntries
我们已经知道可以使用Object.entries
返回对象自身可枚举属性键值对数组,而Object.fromEntries(tc39 proposal)则可以看做是这一过程的逆转,用数组返回可枚举对象,loadash里提供了_.fromPairs(pairs)类似的方法。
var obj = { foo: 1, baz: 2 }; |
String#{trimStart,trimEnd}
这两个方法应该是弥补trim
的不足,trim会直接把两头的空白均移除,trimStart()
方法用于移除字符串开头的空白,trimEnd()
用于移除字符串末尾的空白。
var str = ' ECMAScript 2019 '; |
Symbol.prototype.description
Symbol类型增加description
属性,返回Symbol对象的可选描述的字符串。
Symbol('ECMAScript2019').description; // ECMAScript2019 |
try { } catch {} // optional binding
opitionam bindingtc39 proposal catch参数可选。经常会有这种情况,并没有使用到catch内的参数:
try { |
之后可以这样写:
try { |
JSON ⊂ ECMAScript
JSON也有两处的优化:行分隔符(U+2028)和段分隔符(U+2029)符号现在允许在字符串文字中,与JSON匹配。 以前,这些符号在字符串文字中被视为行终止符,因此使用它们会导致SyntaxError异常。eval('"\u2028"'); // ""
优化JSON.stringify
改进了JSON.Stringify()
方法,防止返回不符合规范Unicode字符串。
// 之前 |
Function.prototype.toString
toString()方法现在能返回源代码字符串,包括空行和注释:function /* a comment */ foo () {}
foo.toString() // "function /* a comment */ foo () {}"
Array.prototype.sort
ECMAScript2019版的sort
会确保Array.sort方法是稳定的。
之前总结的 ES6 新特征点这 => ES6(ECMAScript 6.0)新特征。