ECMAScript 2020 中的可选链和 Nullish 合并运算符实现深层对象读取

AI 编程助手,豆包旗下的编程助手,提供智能补全、智能预测、智能问答等能力,节省开发时间,释放脑海中的创造力,支持 VSCode,点击体验 AI

在前端开发中,我们常常需要访问深层嵌套的对象属性。传统的访问方式可能会因为某个属性不存在而抛出异常,为了解决这个问题,ECMAScript 2020 引入了可选链和 Nullish 合并运算符,让深层对象读取变得更加简单和安全。

可选链

可选链是一种语法糖,用于访问嵌套对象的属性,它可以在属性不存在时返回 undefined 而不是抛出异常。可选链的语法是 ?.,它可以放在任意属性访问操作符的后面。

下面是一个示例代码:

----- ---- - -
  ----- -------
  -------- -
    ----- ---- ------
    ------- ---- -------
  -
--

------------------------------- -- ---- -----
---------------------------------- -- ---------

------------------------ -- ------------------- -- ---- -----
------------------------ -- ---------------------- -- ---------

-------------------------------- -- ---- -----
----------------------------------- -- ---------

这段代码中,我们定义了一个包含嵌套属性的对象 user。在访问 user.address.city 时,如果 address 属性不存在,就会抛出异常。使用可选链可以避免这种情况的发生,如果 address 不存在,那么 user.address.city 的值就会是 undefined。

Nullish 合并运算符

Nullish 合并运算符是一种语法糖,用于在某个属性值为 null 或 undefined 时,返回默认值。它的语法是 ??,它可以放在任意表达式的中间。

下面是一个示例代码:

----- ---- - -
  ----- -------
  -------- -
    ----- ---- ------
    -------- ----
  -
--

-------------------------------- -- ----------- -- ----
------------------------------------ -- ----------- -- ---------

这段代码中,我们定义了一个包含嵌套属性的对象 user。在访问 user.address.zipCode 时,它的值为 null,但是我们并不希望使用默认值,因此使用了 Nullish 合并运算符。在访问 user.address.phoneNumber 时,它的值为 undefined,因此使用了默认值 'unknown'。

可选链和 Nullish 合并运算符的组合使用

可选链和 Nullish 合并运算符可以组合使用,用于访问深层嵌套的对象属性,并在属性值为 null 或 undefined 时返回默认值。下面是一个示例代码:

----- ---- - -
  ----- -------
  -------- -
    ----- ---- ------
    -------- ----
  -
--

--------------------------------- -- ----------- -- ----
------------------------------------- -- ----------- -- ---------

这段代码中,我们定义了一个包含嵌套属性的对象 user。使用可选链和 Nullish 合并运算符可以避免访问不存在的属性时抛出异常,并在属性值为 null 或 undefined 时返回默认值。

总结

可选链和 Nullish 合并运算符是 ECMAScript 2020 中的两个新特性,它们可以帮助我们更加方便、安全地访问深层嵌套的对象属性。在实际开发中,我们可以使用它们来简化代码并提高代码的可读性和健壮性。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/660d2c73d10417a222d91680


猜你喜欢

  • ECMAScript 2021 中的条件语句:回顾 if,else 和 switch 语句

    前言 在编程语言中,条件语句是一种基本的编程结构,用于根据条件来执行不同的代码块。在 ECMAScript 2021 中,if,else 和 switch 语句是最常见的条件语句,它们可以帮助开发人员...

    7 个月前
  • Kubernetes 中使用 PodDisruptionBudget 保障应用高可用

    在 Kubernetes 集群中,Pod 是最小的可调度单元,而应用的高可用性对 Pod 的可用性有着很高的要求。PodDisruptionBudget(PDB)是 Kubernetes 中一种保障应...

    7 个月前
  • RxJS 之 concatMap:深入理解 RxJS 之 concatMap

    RxJS 是一个强大的响应式编程库,它提供了许多操作符来帮助我们处理异步数据流。其中,concatMap 是一个非常有用的操作符,它可以在一个 Observable 发出的每个值上执行一个函数,并将这...

    7 个月前
  • Express.js 中如何处理并发请求,避免阻塞

    在现代 Web 应用程序中,处理并发请求是必不可少的。当多个用户同时访问同一个网站时,服务器需要处理这些请求,并返回正确的响应。在 Express.js 中,我们可以使用一些技术来处理并发请求,避免阻...

    7 个月前
  • Sequelize 中使用原始 SQL 的方法详解

    Sequelize 是一个 Node.js ORM(对象关系映射)框架,可以方便地操作关系型数据库。虽然 Sequelize 提供了丰富的 API,但是有时候我们需要使用原始 SQL 来完成一些复杂的...

    7 个月前
  • 通过修改 GC 参数来优化 JVM 性能

    在 Java 应用程序中,JVM(Java 虚拟机)是非常重要的一环。JVM 负责管理内存、执行字节码等任务。而垃圾回收(GC)是 JVM 中最重要的一个子系统之一。

    7 个月前
  • 特性试验:class 静态数据成员与类私有方法 – ES11 新特性介绍

    前言 JavaScript 是一门动态语言,它的灵活性使得开发者可以快速地创建出各种各样的应用,但是也带来了一些问题,比如说代码可维护性和代码的安全性。ES6 以后,JavaScript 引入了一些新...

    7 个月前
  • Redis 在多租户环境中的应用实践

    随着云计算和 SaaS 模式的普及,多租户架构成为了越来越多企业的选择。在多租户架构中,多个租户共用同一套系统,但是数据和逻辑需要完全隔离。这就要求我们在设计架构时需要考虑如何实现数据的隔离和高效访问...

    7 个月前
  • PWA 应用如何处理 token 失效?

    什么是 PWA 应用? PWA(Progressive Web App)是一种新型的 Web 应用程序,可以在任何设备上运行,包括桌面、移动设备和平板电脑。它们利用现代 Web 技术提供了与原生应用程...

    7 个月前
  • ES7 中 Array.prototype.flat 方法的性能优化实践

    在 ES7 中,新增了 Array.prototype.flat 方法,用于将多维数组打平成一维数组。这个方法非常实用,但是在处理大规模数据时,可能会存在性能问题。

    7 个月前
  • Babel 填坑指南:如果 ES6 的箭头函数引发 Babel 编译问题该如何解决

    随着前端开发的发展,ES6 已经成为了前端开发的一种标准。不过,由于不同浏览器对 ES6 的支持度不同,为了兼容性,我们需要使用 Babel 来将 ES6 转换成 ES5。

    7 个月前
  • 前端 socket 联调神器:如何解决 webpack 项目中 socket.io-client 请求失败问题

    前端 Socket 联调神器:如何解决 Webpack 项目中 Socket.io-Client 请求失败问题 在前端开发中,Socket 技术已经被广泛应用,它可以实现实时通信、实时更新等功能。

    7 个月前
  • 设计 RESTful API 时应考虑的缓存方案

    在设计 RESTful API 时,缓存是一个重要的考虑因素。缓存可以显著提高 API 的性能和可扩展性,减少响应时间和服务器负载。本文将介绍设计 RESTful API 时应考虑的缓存方案,包括缓存...

    7 个月前
  • 解决使用 Jest 测试时无法识别 ES6 模块的问题

    背景 在前端开发中,使用 Jest 进行单元测试是一个常见的做法。然而,当我们在测试 ES6 模块时,可能会遇到无法识别模块的问题,导致测试失败。 原因 Jest 默认使用 CommonJS 模块系统...

    7 个月前
  • 利用 Fastify 进行 HTTP 请求的互通性判断

    在前端开发中,经常会遇到需要进行 HTTP 请求的情况。然而,不同的浏览器或客户端对于 HTTP 请求的支持程度不尽相同,这就给开发带来了一定的困惑。为了解决这个问题,我们可以利用 Fastify 进...

    7 个月前
  • ECMAScript 2021 中的块作用域变量和常量的使用。

    ECMAScript 2021 中的块作用域变量和常量的使用 在 JavaScript 中,变量和常量是我们常常使用的概念。在过去的版本中,声明变量和常量只能使用 var 和 const 关键字。

    7 个月前
  • 如何使用 Async Function 替代 Promise

    在 JavaScript 中,Promise 是一种常用的处理异步操作的方式。然而,使用 Promise 可能会带来一些麻烦,比如回调地狱和代码可读性差等问题。为了解决这些问题,ES2017 引入了 ...

    7 个月前
  • 响应式设计实现弹框 UI 与交互的技巧

    随着移动设备的普及,响应式设计成为了前端开发中不可或缺的一部分。在响应式设计中,弹框 UI 是常见的交互方式,可以用来进行用户信息提示、操作确认等。本文将介绍如何在响应式设计中实现弹框 UI 与交互的...

    7 个月前
  • MongoDB 打补丁的正确姿势:从报错到解决

    前言 MongoDB 是一个使用广泛的 NoSQL 数据库,它的灵活性和可扩展性使得它成为了很多应用的首选。但是,随着使用时间的增长,我们可能会遇到一些问题,例如数据丢失、性能下降等,这时候就需要进行...

    7 个月前
  • ES8 的 async/await 让你的代码更干净、更简洁

    在现代的前端开发中,异步编程已经成为了必不可少的一部分。JavaScript 作为一门单线程语言,异步编程主要通过回调函数、Promise 和 Generator 等方式来实现。

    7 个月前

相关推荐

    暂无文章