ES2021(ES12)新特性解读
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了ES2021(ES12)新特性解读相关的知识,希望对你有一定的参考价值。
参考技术A ECMAScript语言规范的第12个版本发布(ES2021)。来看看怎么使用它们。原有的 replace 如果不用正则表达式只能替换一个,相信不少初学者都塌过这个坑。
如果想要全部替换,我们只能借助全局的正则表达式:
现在使用 replaceAll 不用正则也能达到一样的效果,而且更加直观:
继 all , race , allSettled 这些批处理方法后,又迎来了一个新的 any 。
race 接收 promise 数组中第一个 reslove 的值作为自身的 reslove ,也就是说只要有一个 fulfilled ,它也会是 fulfilled 状态。举个例子:
而当所有 promise 都 rejected 时,那么它将抛出一个 AggregateError 汇总错误消息:
?? , && , || 这三也加入了赋值运算符中,举个例子比较形象:
注:跟 a += b 一样,会改变 a 的值,所以不能 const a 。
在一般情况下,对象的引用是强引用的,这意味着只要持有对象的引用,它就不会被垃圾回收。只有当该对象没有任何的强引用时,垃圾回收才会销毁该对象并且回收该对象所占的内存空间。
而 WeakRef 允许您保留对另一个对象的弱引用,而不会阻止被弱引用对象被垃圾回收。
deref 方法返回实例的目标对象,如果目标对象已被垃圾回收,则返回 undefined 。
FinalizationRegistry 可以让你在对象被垃圾回收时执行回调。
先注册好回调:
其中
注:这两个特性谨慎使用。
为了提高大数字的可读性,现在可以用 _ 作为数字的分隔符:
类似于我们经常看到的 1,000,000,000 ,当然分割线的形式没强制要求隔3位才分割。
这次也提到了,数组 sort 这个特性已经稳定了,早先在 ES2019 已经明确要求,详见 ES2019(ES10)带来的9个新特性 。
ES2015~ES2021 新特性
前言
ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,在 2015 年 6 月正式发布。
ES6 泛指 5.1 版以后的 JavaScript 的下一代标准,涵盖了 ES2015、ES2016、ES2017 等。
JS 标准在每年的 6 月份正式发布一次,作为当年的正式版本。
ES2015
node 支持:node v6.17.1 以上支持 99%。
- ES6 的第一个版本。
ES2016
node 支持:node v7.5.0 以上支持 100%。
- 新增规定只要函数参数使用了默认值、解构赋值、或者扩展运算符,那么函数内部就不能显式设定为严格模式,否则会报错。
- 新增了数组实例的 includes 方法和指数运算符。
ES2017
node 支持:node v9.11.2 以上支持 100%。
Object.getOwnPropertyDescriptors()
返回指定对象所有自身属性(非继承属性)的描述对象。Object.values
和Object.entries
供for...of
循环使用。padStart()
用于头部补全,padEnd()
用于尾部补全。- 引入了 async 函数。
- 允许函数的最后一个参数有尾逗号。
- 引入 SharedArrayBuffer,允许 Worker 线程与主线程共享同一块内存。
ES2018
node 支持:node v12.4.0 以上支持 100%。
- 正则:引入s修饰符,使得.可以匹配任意单个字符,后行断言。
- 引入了“异步遍历器”(Async Iterator),为异步操作提供原生的遍历器接口。
- 模板字符串:遇到不合法的字符串转义,就返回
undefined
,而不是报错。 - 对象引入扩展运算符。
Promise.finally()
不管 Promise 对象最后状态如何,都会执行的操作。
ES2019
node 支持:node v12.4.0 以上支持 100%。
- 新增
trimStart()
和trimEnd()
。 toString()
返回函数代码本身,以前会省略注释和空格,现在明确要求返回一模一样的原始代码。- 允许 catch 语句省略参数。
Array.prototype.sort()
的默认排序算法必须稳定。- Symbol 提供了一个实例属性 description,直接返回 Symbol 的描述。
ES2020
node 支持:node v14.5.0 以上支持 100%。
- import() 动态异步加载。
- globalThis 打通所有环境。
String.prototype.matchAll()
可以一次性取出所有匹配。不过,它返回的是一个遍历器(Iterator),而不是数组。- BigInt 大整数计算保持精度,无位数限制
BigInt(\'123\') 123n typeof 123n === \'bigint\'
。 Promise.allSettled()
只有等到所有这些参数实例都返回结果,不管是 fulfilled 还是 rejected,包装实例才会结束。- 链判断运算符 ?.
直接在链式调用的时候判断,左侧的对象是否为 null 或 undefined,如果是,就不再往下运算,而是返回 undefined
可用
obj?.prop // 对象属性
obj?.[expr] // 同上
func?.(...args) // 函数或对象方法的调用
不可用,报错
// 构造函数
new a?.()
new a?.b()
// 链判断运算符的右侧有模板字符串
a?.`{b}`
a?.b`{c}`
// 链判断运算符的左侧是 super
super?.()
super?.foo
// 链运算符用于赋值运算符左侧
a?.b = c
右侧不得为十进制数值
- Null 判断运算符 ??
只有运算符左侧的值为 null 或 undefined 时,才会返回右侧的值
let num = person.n ?? 100
?? 和 && || 同时用必须用括号表明优先级否则会报错
&& 和 || 的优先级孰高孰低,如果多个逻辑运算符一起使用,必须用括号表明优先级,否则会报错
ES2021
Promise.any()
只要参数实例有一个变成 fulfilled 状态,包装实例就会变成 fulfilled 状态;如果所有参数实例都变成 rejected 状态,包装实例就会变成 rejected 状态。replaceAll()
一次性替换所有匹配\'aabbcc\'.replaceAll(\'b\', \'_\') // \'aa__cc\'
。
参考文档
github 地址
以上是关于ES2021(ES12)新特性解读的主要内容,如果未能解决你的问题,请参考以下文章
分享 5 个你现在就能用上的 Js ES12 新特性(数字分隔符replaceAll()Promise.any()......)