如何在 ECMAScript 2020 中使用可选链操作符?

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

前端开发中经常会涉及到访问对象的属性,但是在实际开发中,有些对象的属性可能不存在,这时候就需要进行判断。在过去,我们通常会通过 ?? 运算符或者使用条件判断语句来确保对象属性的存在。但在 ECMAScript 2020 中,JS 新增了一种可选链操作符(optional chaining),通过它我们可以方便地访问对象的属性,而无需手动去做属性的存在性检测。

可选链操作符的使用

可选链操作符 ?. 是一个非常方便的语法糖,我们可以通过它来进行类似“短路”的操作。当我们以 obj?.foo?.bar?.xxx 的方式访问某个对象 foo.bar.xxx 属性时,如果 obj 对象或者 foo 对象不存在则直接返回 undefined,不再报错了。

示例代码如下:

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

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

在这个示例代码中,我们首先声明了一个 obj 对象,并进行了一系列属性的链式访问。当所有的对象和属性都存在时,message 变量的值为 'Hello, World'。如果存在任何一个对象或者属性不存在,比如 obj.foo.xxx,那么 message 的值就会是 undefined

此外,可选链操作符还可以结合函数的调用来实现更精细的操作。

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

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

在这个示例代码中,我们在 xxx 属性上定义了一个无参函数。如果所有的对象和属性都存在时,执行 obj?.foo?.bar?.xxx?.(); 就会输出 'Hello, World!'。如果 bar 对象不存在时,函数就不会被调用。

可选链操作符的高级用法

除了基本操作之外,可选链操作符还有一些高级的用法,能够让我们的代码更加简洁。

使用连续的判断

在过去,我们一般会使用连续的条件判断语句来检测对象的属性是否存在。例如:

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

但是使用可选链操作符之后,我们可以用更加简洁的方式来达到相同的效果:

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

短路表达式

当我们需要进行一些复杂的属性访问操作时,可选链操作符同样也很好用。

例如,当我们需要访问一个数组中的某个元素时,我们通常需要使用条件判断语句来防止数组溢出。如下所示:

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

但是使用可选链操作符之后,我们就可以直接写出一行代码来实现这个操作:

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

空值合并运算符

在过去,判断一个对象属性是否存在的方法通常是使用三元运算符或者 || 运算符。例如:

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

但是在 ECMAScript 2020 中,我们可以使用空值合并运算符(nullish coalescing operator)来更加优化这个操作,如下所示:

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

这里的 ?? 运算符会仅在 obj.titlenull 或者 undefined 时才返回 'Untitled'

结论

在本文中,我们介绍了 ECMAScript 2020 中的可选链操作符的使用。我们发现可选链操作符是一种非常简洁、方便、实用的语法糖,既可以减少大量的手动属性存在性检测的代码,同时也提高了代码的可读性和可维护性。当然,这项新特性在某些老的浏览器中可能不被支持,但我们可以通过使用 Babel 等工具来实现后向兼容。

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


猜你喜欢

  • 如何使用 Fastify 解决 API 并发请求问题

    在现代 Web 应用程序中,API 通常是构建 web 服务的基石。然而,在与许多客户端、大量请求或资源有限的情况下,API 的性能可能会受到并发请求的影响。Fastify 是一个高度优化的 Web ...

    15 天前
  • Node.js 中的性能优化技巧

    作为前端开发人员,我们经常需要编写高性能的 Node.js 应用程序或服务端代码。然而,随着应用程序越来越庞大和复杂,我们很容易遇到性能瓶颈和延迟等问题。本文将介绍一些常用的性能优化技巧,帮助你在开发...

    15 天前
  • Deno 与 TypeScript 的关系探讨

    什么是 Deno? Deno 是一个基于 V8 引擎构建的运行时环境,用于在浏览器外运行 JavaScript 和 TypeScript。它由 Ryan Dahl 创建,他也是 Node.js 项目的...

    15 天前
  • 如何解决 Promise.all 遇到 reject 只执行部分 promise 的问题

    使用 Promise.all 可以同时执行多个 promise,并在所有 promise 都完成(即所有 promise 都 fulfilled 或有至少一个 promise rejected)后返回...

    15 天前
  • 为什么 SSE 比 WebSocket 在实时通信方面更有优势

    随着互联网的发展,实时通信已经变成了当今 Web 应用程序中非常重要的功能。WebSocket 和 SSE(Server-Sent Events)是两种实现实时通信的方法,但它们有所不同。

    15 天前
  • 如何使用 Webpack 构建简单的 HTML 页面

    前言 Webpack 是一个强大的构建工具,可以用于将多个 JavaScript 文件打包成一个或多个 bundle 文件。但是,它不仅限于 JavaScript 文件。

    15 天前
  • 如何解决 Headless CMS API 传输速度慢的问题?

    随着前端技术的发展和变革,Headless CMS(无头内容管理系统)成为了越来越多网站和应用的选择。相比于传统的 CMS,Headless CMS 更加灵活,便于前后端分离开发。

    15 天前
  • Mocha 测试框架中如何使用 before/after 钩子

    引言 Mocha 是一个前端自动化测试框架,能够帮助我们编写测试用例和测试脚本。在编写测试用例时,我们经常需要在运行每个测试用例之前(或之后)进行某些操作,在 Mocha 中,我们可以使用 befor...

    15 天前
  • Redis 持久化与内存混合保存方式的权衡

    前言 在开发过程中,Redis 是一个非常流行的缓存和键值存储数据库,它能够快速访问和存储数据,并且支持多种数据结构。然而,在使用 Redis 时,开发人员必须考虑如何进行数据持久化,以确保服务器出现...

    15 天前
  • 为什么你的响应式布局出现错位问题?

    在进行前端响应式布局时,常常会有布局错位的问题出现。这个问题通常出现于设计平台和浏览器的差异以及不充分的兼容性测试。为了解决这个问题,我们需要仔细检查布局代码,并具备一些响应式布局的知识。

    15 天前
  • React 测试进阶之详解 Enzyme

    在 React 开发中,测试是非常重要的一环。React 提供了一些官方的测试工具,比如 Jest。然而,对于测试 React 组件来说,有一款非常流行的第三方库:Enzyme。

    15 天前
  • 使用 LESS 报错:'calc()' is not a valid value for property

    在前端开发中,我们经常会使用 CSS 预处理语言,其中 LESS 是一个非常流行的选择。它可以使我们的样式表更加易于维护和扩展。然而,在使用 LESS 的过程中,有时我们会遇到一些奇怪的错误信息,比如...

    15 天前
  • 如何用ES6的Class进行面向对象编程

    ES6的Class是JavaScript中非常重要的一个功能,使用它能够轻松的进行面向对象编程。在本文中,我们会介绍Class的一些基础知识,如何用它来编写面向对象的代码,以及如何扩展现有的类。

    15 天前
  • 通过 GraphQL 实现数据库类型的模糊搜索

    在 Web 开发中,搜索是一个非常重要的功能之一。而实现搜索功能的核心便是数据库查询。如何快速、准确、高效地查询数据成了前端工程师们需要思考的问题之一。 在本文中,我们将介绍如何通过 GraphQL ...

    15 天前
  • 解决使用 CSS Grid 布局后文本换行错乱的问题

    在前端开发中,CSS Grid 布局是一种非常流行的布局方式。它可以轻松实现复杂的布局,简化了开发流程,同时也提高了网页的可读性和可维护性。然而,在使用 CSS Grid 布局时,可能会遇到一些小问题...

    15 天前
  • C++ 程序性能工具箱的选用和使用

    C++ 是一种高性能的编程语言,但是对于程序开发人员来说,如何保证自己的程序在运行时能够达到最佳的性能是一个需要重视的问题。为了解决这个问题,C++ 程序性能工具箱应运而生。

    15 天前
  • RxJS 实现多个异步操作的串行执行

    随着 Web 应用程序的发展,越来越多的异步操作在前端中被使用,如异步请求、异步数据加载等。但是,当需要在多个异步操作中实现串行执行时,经常需要使用大量的回调函数来管理异步操作的控制流,使代码变得混乱...

    15 天前
  • Serverless 架构下的 Lambda 层使用技巧

    随着云服务的快速发展,Serverless 架构成为了越来越流行的开发方式。Serverless 架构的优点非常明显,例如无服务器管理、低成本维护、无需管道水平扩展等。

    15 天前
  • 深入理解 Promise.all() 并发请求

    在现代的前端开发中,我们通常需要进行并发请求,以便同时从不同的数据源中获取数据。Promise.all() 是一种强大的工具,它可以帮助我们轻松地管理并发请求。本文中,我们将深入探讨 Promise....

    15 天前
  • 无障碍标准 | 无障碍标准及其应用实践

    前言 今天,我们将要讨论的是一种非常重要的技术标准 - 无障碍标准。在以前,人们很少关注无障碍标准,但是现在,随着互联网应用的广泛使用,人们开始意识到无障碍标准的重要性,越来越多的公司和组织开始采用无...

    15 天前

相关推荐

    暂无文章