ES2021+ES2022 你知道几个呢?

自建博客文章链接:http://www.heblogs.cn/articleDetails/62344bc503cf170af0468fbb

仔细想下 很久没有发博客了 最近确实挺忙的 公司一直在喊冲刺冲刺 加班比较多 心思都在需求上 最近还是忙里偷闲坚持写下一篇博客
这种习惯坚决不能落下

  • ES2021(ES12) 于2021年6月22日发布,新特性在最新版Google已支持
  • ES2022(ES13)也会在今年6月份发布,我们可以提前看看有什么新特性

ES2021

1.String.prototype.replaceAll()

//before ES12
'jxvxscript'.replace('x', 'a');//javxscript
//before ES12
'jxvxscript'.replace(/x/g, 'a');//javascript
//new ES12
'jxvxscript'.replaceAll('x', 'a');//javascript

2. Promise.any
Promise.any() 接收一个Promise可迭代对象的数组,只要其中的一个 promise 成功,就返回那个已经成功的 promise 。 如果可迭代对象中没有一个 promise 成功(即所有的 promises 都失败/拒绝),就返回一个失败的 promise。

const promise1 = new Promise((resolve, reject) => reject('失败1'));
const promise2 = new Promise((resolve, reject) => reject('失败2'));
const promiseList = [promise1, promise2];
 
Promise.any(promiseList).then(values=>{  
  console.log(values);
})
.catch(e=>{  
  console.log(e);
})

3.逻辑赋值运算符

let a = 1
let b = 2

//before ES12
if(a){
  a = b
}
//new ES12
a &&= b

//before ES12
if (!a) {
  a = b
}
a = a || b
//new ES12
a ||= b


//before ES12
if( a==null || a==undefined ){
  a=b
}
//new ES12
a ??= b

4.数字分隔符

// before ES12
const number = 92145723;
 
// new ES12
const number = 92_145_723
console.log(number) // 92145723
 
//对国人来说可以万 亿为单位 便于阅读
const number = 1_0000_0001;
console.log(number) // 100000001

ES2022

ES2022会在今年6月份提出新版本 让我们拭目以待吧

1.error.cause

这是一个关于错误捕获的特性,下文代码列举了过去我们常使用的三种捕获错误的方式

async function doJob() {
  const rawResource = await axios('/test')
    .catch(err => {
      // 下面三种是过去常用的一些捕获错误的代码方式
      
      // 1. throw new Error('下载资源失败: ' + err.message);
      
      // 2. const wrapErr = new Error('下载资源失败');
      //    wrapErr.cause = err;
      //    throw wrapErr;
      
      // 3. class CustomError extends Error {
      //      constructor(msg, cause) {
      //        super(msg);
      //        this.cause = cause;
      //      }
      //    }
      //    throw new CustomError('下载资源失败', err);
    })
}

await doJob(); // => Uncaught Error: 下载资源失败: Failed to fetch

过去的捕获错误的写法比较复杂,而且开发人员对具体使用哪个属性来获取错误的上下文没有达成共识。

新特性是在 Error 构造函数上添加一个附加选项参数 cause,其值将作为属性分配给错误实例。因此,可以将错误链接起来。

async function doJob() {
  const rawResource = await axios('/test')
    .catch(err => {
      throw new Error('下载资源失败', { cause: err });
    });
}

try {
  await doJob();
} catch (e) {
  console.log(e);
  console.log('Caused by', e.cause);
}
// Error: 下载资源失败
// Caused by TypeError: Failed to fetch

2. Top-level await
我们现在可以在模块的顶层使用 await, 并且不再需要配合 async函数使用。

Top-level await 可以在实际生产中有以下用途。

动态加载模块

const strings = await import(`/i18n/${navigator.language}`);

这允许模块使用运行时值来确定依赖关系。这对于开发/生产拆分、国际化、环境拆分等非常有用。

资源初始化

const connection = await dbConnector();

允许模块表示资源。

依赖回退

let jQuery;
try {
  jQuery = await import('https://cdn-a.com/jQuery');
} catch {
  jQuery = await import('https://cdn-b.com/jQuery');
}

3. Object.hasOwn(obj, propKey)
Object.hasOwn() 方法是比 Object.prototype.hasOwnProperty() 方法更加 便捷 和 安全 的策略。
例如 Object.create(null) 创建一个不继承自 Object.prototype 的对象,使 hasOwnProperty 方法无法访问。

Object.create(null).hasOwnProperty("foo")
// Uncaught TypeError: Object.create(...).hasOwnProperty is not a function

Object.hasOwn(obj, propKey) 使用案例。

let object = { foo: false }
Object.hasOwn(object, "foo") // true

let object2 = Object.create({ foo: true })
Object.hasOwn(object2, "foo") // false

let object3 = Object.create(null)
Object.hasOwn(object3, "foo") // false

4. RegExp match indices
正则表达式,继 /i /m /g 之后,在匹配模式上新加入了 /d,使用 /d 之后,当我们再使用exec() 方法时,返回值会增加一个新的属性 indices。
简单回顾下exec() 方法。
相比于常见的 search() test()而言,exec() 匹配字符串的信息更丰富,它返回一个数组,其中存放匹配的结果,如果未找到匹配,则返回值为 null

let regx = /a+(?<Z>z)?/g; 
let string = "xaaaz"
let result = regx.exec(string);
// ['aaaz', 'z', index: 1, input: 'xaaaz', groups: {Z:'z'}]

(?)是 ES 2018 加入的正则语法,允许我们把部分正则内容进行 命名 并且 分组,上述例子中,/a+(?z)?/g表示匹配至少一个 a 以及 0 个或者 1 个 z ,其中包含一个命名为 Z 的捕获组,配合 exec() 方法使用时,我们可以直接获取到捕获组的信息:result.groups,如果正则中没用使用捕获组的正则语法,则 groups 为 undefined
尽管 exec() 返回值提供了 index 属性 来展示首次匹配的索引位置,groups 属性 提供了捕获组的信息,但在一些更高级的场景中,这些信息可能并不足够。例如,语法高亮显示 的实现不仅需要匹配的索引,还需要单个捕获组的开始和结束索引,即上述例子中 Z 捕获组的索引信息。
新特性中,使用 /d匹配模式时,exec() 方法的返回值会增加一个新的属性 indices。

const re = /a+(?<Z>z)?/d;
const s = "xaaaz";
console.log("匹配结果:", re.exec(s));
//['aaaz', 'z', index: 1, input: 'xaaaz', groups: {Z:'z'}, indices: [[1,5],[4,5]]

indices属性包含了捕获组的信息,其中,[ 1 , 5 ] 为 aaaz 全部字符串的匹配信息,[ 4 , 5 ] 为 Z 捕获组的匹配索引信息。

5. New members of classes 简易变量声明
class 支持在 constructor 外部直接声明变量,过去我们必须在内部声明。

class Cat {
  gender = 'female'
}
let cat = new Cat()
cat.gender // female

6. at()
.at()支持我们读取给定索引处的元素。它可以接受负索引来从给定数据类型的末尾读取元素。
过去我们需要这样来获取数组末尾元素:
代码的语义会更直观更清爽,非常的方便!
支持类型:

  • String
  • Array
  • Typed Array
//before ES13
const arr = [1,2,3,4,5]; 
arr[arr.length-1] // 5
// new ES13
const arr = [1,2,3,4,5]; 
arr.at(-1) // 5
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hhua.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值