关于 ECMAScript 2019 中的 nullish coalescing 运算符的使用细节

在新推出的 ECMAScript 2019 中,新引入了一种运算符 nullish coalescing(空值合并),用于处理变量为空或者undefined的情况。本文将详细介绍该运算符的使用细节,以及如何在前端开发中合理使用。

什么是 nullish coalescing 运算符

nullish coalescing 运算符用于替代传统的 || 运算符,在某些特定情况下更为准确地确定变量值。该运算符用两个?号(??)表示,其语法为:

- -- --

该语法中,a 和 b 都是表达式。当 a 为 null 或 undefined 时,返回 b 的值,否则返回 a 的值。

与 || 运算符的区别

在之前的 JavaScript 版本中,我们通常使用 || 做为 null 或者 undefined 的默认值。例如:

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

但是这种写法在某些情况下会存在问题,考虑下面的代码:

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

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

可以看到,当 x 使用 || 运算符时,返回了不是我们期望的 'default',这是一种常见的坑点。而 nullish coalescing 运算符可以正确地返回期望的 'default':

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

如何精选 nullish coalescing 运算符

在实际项目中,我们可能会遇到多个变量需要做默认值,此时需要注意使用nullish coalescing 运算符。

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

如果 a 是一个空字符串,则 x 和 y 都会选择 b ,但是 z 会选择 a,这是因为 a 的值不是 null 或 undefined。这是一个非常微妙的区别,需要非常注意。

了解 nullish coalescing 运算符的优先级

在使用过程中需要注意的是,nullish coalescing 运算符的优先级比 || 运算符更低,是所有运算符中最低的。因此在使用时,需要特别注意。

以下代码可以帮助我们了解不同运算符的优先级:

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

我们期望的输出应该是 'hello',但是实际上返回的是 undefined,这是因为 || 运算符优先级高于 nullish coalescing 运算符,因此可以这样改写代码:

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

总结

本文详细介绍了 ECMAScript 2019 中的 nullish coalescing 运算符的使用细节,与传统的 || 运算符的区别以及一些注意事项。在实际项目中,需要特别注意 nullish coalescing 运算符的使用,避免出现不必要的错误。

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


猜你喜欢

  • Node.js 中使用 Cookie-Session 进行用户会话管理

    什么是 Cookie-Session? Cookie-Session 是一个基于 Cookie 实现的会话管理工具。它可以在客户端存储会话信息,并在后续的请求中自动发送这些信息到服务器端,从而实现用户...

    10 个月前
  • 使用 ESLint 进行代码自动化格式化

    在前端开发中,代码的规范性是非常重要的。代码规范性不仅能提高代码的可读性和可维护性,还能减少代码错误和提高开发效率。而使用 ESLint 进行代码自动化格式化,则是实现代码规范性的一种有效方式。

    10 个月前
  • ECMAScript 2020(ES11):什么是折叠匹配表达式(match folding)?

    在 ECMAScript 2020(ES11)中,新增了一种正则表达式的特性——折叠匹配表达式(match folding)。这个特性可以帮助我们更方便、更准确地匹配字符串,下面我们来详细学习一下。

    10 个月前
  • Vue.js 中使用 Vuex 和 Vue-Router 实现根据用户角色动态生成菜单

    在前端开发中,我们经常需要根据用户的角色来动态生成菜单,以便于用户能够快速找到自己所需要的功能。在 Vue.js 中,我们可以通过使用 Vuex 和 Vue-Router 来实现这个功能。

    10 个月前
  • 无障碍键盘操作技巧及其应用于 Web 浏览器的实现方法

    在现代社会中,随着互联网的发展,Web 应用程序已经成为人们日常生活中不可或缺的一部分。然而,对于一些身体上存在障碍的人来说,使用鼠标进行网页浏览和操作可能会带来困难。

    10 个月前
  • 使用 Server-Sent Events 实现跨域请求

    在前端开发中,跨域请求是一个常见的问题。为了解决这个问题,我们通常使用 JSONP 或者 CORS 等技术来实现跨域请求。但是这些技术都有一些限制,比如 JSONP 只支持 GET 请求,而 CORS...

    10 个月前
  • Next.js 项目使用 styled-components 时样式失效的问题解决方法

    在前端开发中,我们经常使用 styled-components 来管理项目的样式,而 Next.js 则是一个非常流行的 React 框架。然而,在使用这两个工具的时候,我们可能会遇到样式失效的问题。

    10 个月前
  • CSS Flex 搞定字符溢出 —— 版本分享方案

    在前端开发中,字符溢出是一个常见的问题。当我们的文本内容超出容器的宽度时,就会出现字符溢出的情况。这不仅会影响页面的美观度,还可能对用户体验产生不良影响。为了解决这个问题,我们可以使用 CSS Fle...

    10 个月前
  • 如何解决 MongoDB 安装完成后找不到服务

    背景 MongoDB 是一种非关系型数据库,被广泛应用于 Web 应用程序的后端开发。在使用 MongoDB 时,有时会出现安装完成后无法找到服务的情况,这将导致无法启动 MongoDB,从而使应用程...

    10 个月前
  • Koa 中如何使用 Router 实现路由控制?

    路由控制是 Web 开发中的一个重要环节,它决定了客户端请求如何被服务器处理。在 Koa 中,我们可以使用 Router 来实现路由控制。本文将介绍如何在 Koa 中使用 Router 实现路由控制,...

    10 个月前
  • 类型检查工具 TypeScript 与 Jest 结合使用的技巧分享

    前端开发中,我们常常会遇到一些类型错误导致的问题。为了避免这类问题的出现,我们可以使用 TypeScript 这样的类型检查工具。但是,使用 TypeScript 并不能完全避免问题的出现。

    10 个月前
  • SASS 中的注释方法及使用场景

    在前端开发中,注释是一个非常重要的部分,它可以帮助我们更好地理解代码,也可以帮助其他开发者更好地理解我们的代码。在 SASS 中,注释同样是非常重要的,因为它可以帮助我们更好地组织和管理我们的代码,提...

    10 个月前
  • Hapi 框架中如何使用 Hapi-Compress 插件进行压缩处理?

    在现代 Web 应用中,性能是一个非常重要的问题。其中一个关键因素是页面的加载速度。为了加快页面加载速度,我们可以使用压缩算法来减小页面的大小。在 Hapi 框架中,我们可以使用 Hapi-Compr...

    10 个月前
  • Sequelize 在 Sails.js 中的应用实践

    在 Sails.js 中,Sequelize 是一种常见的 ORM(对象关系映射)库,它可以帮助我们更方便地操作数据库。本文将介绍 Sequelize 在 Sails.js 中的应用实践,并提供详细的...

    10 个月前
  • Mongoose 路由及 Controller 最佳实践

    前言 Mongoose 是 Node.js 中非常流行的一种 ODM(Object Document Mapping)工具,它可以帮助我们更方便地与 MongoDB 进行交互。

    10 个月前
  • Redis 安装让人头疼?别着急,这里有最易操作的教程

    前言 Redis 是一个开源的内存数据结构存储系统,它可以用作数据库、缓存和消息代理。在前端开发中,我们经常会用到 Redis 来存储一些临时数据或者缓存数据等。但是,很多人在安装 Redis 的时候...

    10 个月前
  • 解决 Express.js 中文件上传的 IO 问题

    在 Web 开发中,文件上传是常见的需求之一。而 Express.js 作为流行的 Node.js Web 框架,也提供了文件上传的中间件 multer。然而,在上传大文件时,可能会遇到 IO 问题,...

    10 个月前
  • 在 ES9 中使用 JSON.stringify 的 “space” 参数进行格式化

    在前端开发中,我们经常需要将 JavaScript 对象转换为 JSON 字符串。而 JSON.stringify() 方法是一个常用的工具,它可以将 JavaScript 对象转换为 JSON 字符...

    10 个月前
  • Performance Optimization: 如何确保应用程序的可扩展性?

    前言 前端应用程序的可扩展性是指应用程序在不同场景下(如访问量增加,数据量增加等)仍能保持稳定的性能。随着互联网的快速发展,越来越多的公司开始转向在线业务,并且越来越多的用户开始使用在线服务,因此,确...

    10 个月前
  • 如何使用 Enzyme 测试 React 组件的数据传递

    在 React 开发中,组件的数据传递是非常重要的一部分。为了确保组件能够正确地传递数据,我们需要进行测试。Enzyme 是 React 的一个测试工具,它可以帮助我们轻松地测试组件的数据传递。

    10 个月前

相关推荐

    暂无文章