七个你可能还不知道的强大的 JavaScript 特性

开发 前端
在本文中,我们将探讨大多数开发人员可能不知道的7个很酷的现代 JavaScript 特性。

1.可选链接

可选链接是 JavaScript 中的一项新功能,它允许开发人员编写更简洁、更易于阅读的代码。使用可选链接,您可以访问对象的嵌套属性,而不必担心这些属性是否存在。

const user = {
  name: 'John',
  address: {
    city: 'New York',
    state: 'NY'
  }
};


console.log(user?.address?.city); // Output: New York
console.log(user?.address?.zipCode); // Output: undefined
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.

在上面的示例中,我们使用可选的链接运算符 (?.) 来访问地址对象的 city 属性。如果 address 对象不存在,或者它没有 city 属性,代码将简单地返回 undefined。

2. 无效合并运算符

nullish 合并运算符 (??) 是 JavaScript 中的另一个新功能,可用于为可能为 null 或未定义的变量提供默认值。

const name = null ?? 'John';


console.log(name); // Output: John
  • 1.
  • 2.
  • 3.
  • 4.

在上面的示例中,我们使用 nullish 合并运算符将默认值“John”分配给 name 变量,因为它的初始值为 null。

3.Promise.allSettled()

Promise.allSettled() 方法是 JavaScript 中 Promise API 的新增功能。它允许开发人员同时运行多个Promise并获得所有Promise的结果,无论它们是解决还是拒绝。

const promises = [
  Promise.resolve(1),
  Promise.reject('Error'),
  Promise.resolve(3)
];


Promise.allSettled(promises)
  .then(results => console.log(results));


// Output:
// [
//   { status: 'fulfilled', value: 1 },
//   { status: 'rejected', reason: 'Error' },
//   { status: 'fulfilled', value: 3 }
// ]
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.
  • 12.
  • 13.
  • 14.
  • 15.
  • 16.
  • 17.

在上面的示例中,我们使用 Promise.allSettled() 方法同时运行三个Promise,然后记录所有承诺的结果,包括被拒绝的结果。

4. 对象.fromEntries()

Object.fromEntries() 方法是 JavaScript 中对象 API 的新增功能。它允许开发人员从键值对数组创建对象。

const entries = [
  ['name', 'John'],
  ['age', 30],
  ['city', 'New York']
];


const obj = Object.fromEntries(entries);


console.log(obj); // Output: { name: 'John', age: 30, city: 'New York' }
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
  • 10.
  • 11.

在上面的示例中,我们使用 Object.fromEntries() 方法从键值对数组创建对象。

5.BigInt

BigInt 数据类型是 JavaScript 的新增功能,它允许开发人员使用大于 Number 数据类型支持的最大值的整数。

const a = BigInt(9007199254740991);
const b = BigInt(9007199254740991);


console.log(a + b); // Output: 18014398509481982n
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.

在上面的示例中,我们使用 BigInt 将两个非常大的数字相加。

6.可选的 Catch 绑定

可选的 catch 绑定是 JavaScript 中的一项新功能,它允许开发人员在不需要参数的情况下捕获错误。这可以使代码更简洁,更易于阅读。

try {
// some code that may throw an error
} catch {
// handle the error without a parameter
}
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.

在上面的示例中,我们使用可选的 catch 绑定来捕获错误而不指定参数。如果您不需要在 catch 块中使用错误对象,这会很有用。

7.数组.prototype.flatMap()

Array.prototype.flatMap() 方法是 JavaScript 中 Array API 的新增功能。它允许开发人员在一个步骤中映射然后展平数组。

const arr = [1, 2, 3, 4];


const result = arr.flatMap(x => [x * 2]);


console.log(result); // Output: [2, 4, 6, 8]
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.

在上面的示例中,我们使用 Array.prototype.flatMap() 方法将数组的每个元素乘以 2,然后将结果数组展平为单个数组。

结论

这些只是可供开发人员使用的许多很酷的现代 JavaScript 功能中的一小部分。通过跟上语言的最新更新,您可以编写更高效、更简洁的代码,并利用可以帮助您成为更好的开发人员的新工具和技术。


责任编辑:华轩 来源: web前端开发
相关推荐

2023-11-06 11:32:46

CSS选择器作用域

2020-12-14 07:51:16

JS 技巧虚值

2021-03-18 14:02:56

iOS苹果细节

2021-07-12 07:59:06

安全 HTML 属性

2023-02-20 15:04:24

开发API工具

2023-02-21 15:25:33

开发工具API

2025-02-27 08:33:13

2024-04-01 07:58:49

Next.js 14ReactWeb应用

2022-05-05 12:02:45

SCSS函数开发

2023-03-19 16:02:33

JavaScrip技巧编程语言

2017-11-07 21:58:25

前端JavaScript调试技巧

2020-11-03 09:51:04

JavaScript开发 技巧

2013-05-31 10:57:32

html5html5 api

2021-10-22 09:41:26

桥接模式设计

2024-09-11 16:21:09

2025-03-19 09:46:45

2020-05-09 08:48:21

JavaScript原生方法代码

2012-11-23 10:57:44

Shell

2022-10-13 11:48:37

Web共享机制操作系统

2010-09-13 16:12:06

Mozilla实验室
点赞
收藏

51CTO技术栈公众号