ECMAScript 2022 是一项新的 JavaScript 标准,将于 2022 年 6 月发布。
1. 数组中的at()方法
ES2022将为我们提供一种可能性,即从末端索引类似数组的对象。这是一个很小的功能,但它提高了处理数组或字符串时的核心可读性。
At()方法中的正数与[]索引的作用相同,但如果是负数,则允许从末尾访问数值。
原来:
const arr = [1,2,3,4] arr[arr.length - 2] // 3 arr.slice(-2)[0] // 3
const str = "1234" str[str.length - 2] // '3' str.slice(-2)[0] // '3'
|
新的at()方法:
const arr = [1,2,3,4] arr.at(-2) // 3
const str = "1234" str.at(-2) // '3'
|
2. 错误原因
.cause对象上的.cause属性将允许我们指定哪个错误导致其他错误。非常不言而喻吧?在这里你可以看到这个新功能的一个使用例子。
try { doSomeComputationThatThrowAnError() } catch (error) { throw new Error('I am the result of another error', { cause: error }) }
|
错误原因将是一个完美的方法,可以将错误连在一起,这在其他编程语言如Java中是可能的。
3. 顶层的await
你知道你不能在函数之外的代码中直接使用await吗?如果不知道,那么这对你来说不是什么大问题。但对于其他人来说--不必担心,因为ES2022将改变这一点。const serviceName = await fetch("https://example.com/what-service-should-i-use") const service = await import(<code>/services/${serviceName}.js</code>)
// OR
const params = new URLSearchParams(location.search); const theme = params.get('theme'); const stylingFunctions = await import(<code>/styling-functions-${theme}.js</code>);
|
const date = new Date()
if(date.getFullYear() === 2023) { await require('/special-code-for-2023-year.js') }
|
4. 私有槽slot和方法
纯Javascript中的类从ES6开始就存在了,但与面向对象的语言相比,它们的开发程度要低很多。许多开发者使用Typescript来包含其中的一些功能,现在我们可以看到在纯Javascript类中被实现。
私有槽是其中之一。它们只不过是类的私有属性。ES2022将为我们提供创建它们的可能性,当我们试图在类之外访问它们时,会得到一个错误。私有方法也是如此。有趣的是,JS团队选择给他们#前缀(这与JS的传统有关吗?)
class Human { #name = "John"; setName(name) { this.#name = name; } }
const human = new Human() human.#name = 'Amy' // ERROR! human.setName('Amy') // OK
|
私有方法:
class Human { name = "John"; constructor(name) { this.#setName('Amy') // OK } #setName(name) { this.name = name; } }
const human = new Human() human.#setName('Amy') // ERROR!
|