ES11 新增功能

BigInt

早期的 JavaScript 中,不能正确表示过大的数字,大于 MAX_SAFE_INTEGER 的数值可能不正确,在ES11中,引入了新的数据类型 BigInt ,用于表示大的整数。

//  ES11 之前 max_safe_ integer
const maxInt = Number.MAX_SAFE_INTEGER
console.log (maxInt) // 9007199254740991
// ES11 之后:BigInt
const bigInt = 900719925474099100n
// 打印 900719925474099110n,必须在10后加n
console.log(bigInt + 10n)
const num = 100
// int 转换 BigInt
console.log (bigInt + BigInt (num) )

?? Nullish Coalescing Operator 空值合并运算

一般用于设置变量默认值。

let foo = 0
// 设置默认值,使用||的弊端,当foo为空字符串或为0时,会变成右边值
// let bar = foo || 'default value'

let bar = foo ?? 'default value'
// 打印 0
console.log(bar)

? Optional Chaining 可选链

const info = {
  name: 'tom',
}
// 报错
console.log(info.friend.girlFriend.name)
// ES11之前
if (info && info.friend && info.friend.girlFriend) {
  console.log(info.friend.girlFriend.name)
}
// ES11 简洁
console.log(info.friend?.girlFriend?.name)

Global This 全局对象

在之前我们希望获取 JavaScript 环境的全局对象,不同的环境获取的方式是不一样的:

  • 在浏览器中可以通过 thiswindow 来获取;
  • Node 中我们需要通过 global 来获取;
    在 ES11 之后,可以直接访问 globalThis 获取全局对象。

for … in 标准化

const obj = {
  name: 'tom'
}
for (const key in obj) {
  // ES11 规定 key 的值为对象的 key
  console.log(key)
}

Dynamic Import 动态导入

import('/component').then()

Promise.allSettled

import meta

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注