ECMAScript 2019 如何实现可选链操作符(Null Propagation Operator)的兼容性

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

ECMAScript 2019 引入了可选链操作符(Null Propagation Operator),这种语法可以使得我们查询嵌套对象时不再需要判断对象是否存在,从而减少代码中的冗余操作。这种语法非常实用,然而在某些浏览器中还没有得到支持,这对前端的开发带来了一些不便,本文将介绍如何在实现浏览器兼容性方面得到帮助。

可选链操作符简介

可选链操作符简写为(?.),它可以让我们在获取一个嵌套对象的属性值时判断该嵌套对象是否存在,如果存在则返回该属性值,如果不存在则返回 undefined。这样可以减少很多冗余代码,代码变得更加简洁易懂。例如:

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

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

当 person 对象存在 gender 属性时,输出 'male';当 person 对象不存在 age 属性时,输出 undefined。

可选链操作符的兼容性

尽管可选链操作符非常实用,但是在某些浏览器中还没有得到支持,这对于前端的开发带来了一些不便。目前(2021年4月)只有较新的浏览器(如 Chrome 80、Firefox 74、Safari 13.1、Edge 80)支持该语法,为了更好的兼容性,我们可以使用第三方库或者手动写一些兼容性代码。

使用 Babel 转义可选链操作符

Babel 是一个 JavaScript 编译器,它可以将 ECMAScript 6 及以上版本转化为能够在较老版本浏览器中执行的代码。在使用 Babel 时,可以使用 @babel/plugin-proposal-optional-chaining 插件来支持可选链操作符。具体步骤如下:

  1. 安装 Babel:
--- ------- ----------- ----------
  1. 安装 @babel/plugin-proposal-optional-chaining 插件:
--- ------- ---------------------------------------- ----------
  1. 配置 Babel,在 babel.config.js 文件中添加以下代码:
-------------- - -
  -------- -
    -
      --------------------
      -
        -------- -
          ----- -----
          -------- -----
          ------- -----
          ------- -------
        --
        ------------ --------
        ------- -------
      -
    -
  --
  -------- -
    ------------------------------------------
  -
--

其中:

  • presets 属性表示应用的预设,这里使用了 targets 预设来指定要支持的浏览器和系统环境。
  • plugins 属性表示要使用的插件,这里使用了 @babel/plugin-proposal-optional-chaining 插件。

这样,在打包代码时,Babel 会自动将可选链操作符转化为支持的语法。需要注意的是,需要使用 Babel 的开发者,要安装相应的插件(如 @babel/core 和 @babel/preset-env),Babel 的使用还需要配置相应的文件(如 babel.config.js)来指定转译的规则。

手动实现可选链操作符兼容性

当然,我们也可以手动实现可选链操作符的兼容性。这里我们定义一个名为 q 的函数,可以查询嵌套对象中的属性值,如果对象不存在,则返回 undefined。

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

使用该函数时,可以这样写:

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

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

这个函数实现了可选链操作符相似的功能,但是需要手写代码,实用性和可读性不如可选链操作符。

使用第三方库

第三方库是一个非常便利的解决方案,例如 Lodash、Underscore 等有很多已经实现了可选链操作符的库,使用这些库可以非常简单的实现兼容性。例如使用 Lodash 库,如下:

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

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

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

Lodash 是一个非常常用的 JavaScript 工具库,它包含了许多常用的函数和工具类,使用 Lodash 实现可选链操作符就是通过使用 _.get() 方法实现的。

总结

可选链操作符是 ECMA 系列标准最新的语法之一,它可以使得查询嵌套对象属性值不再需要判断嵌套对象是否存在,提高了代码的简洁性和可读性。尽管该语法还没有得到所有浏览器的支持,但是我们可以使用 Babel 、手动实现、使用第三方库等方式来实现兼容性。由于第三方库等方式其安装和实现基本都可以通过 npm 快速完成,因此我个人推荐使用第三方库的方式实现兼容性。若使用 Babel 的方式,则需要开发者配置规则来进行转义,相信未来我们在浏览器上也能看到更加便捷的实现方式。

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


猜你喜欢

  • Kubernetes 中如何进行应用的安全管理

    在当今互联网时代,应用安全管理成为了重中之重。而在 Kubernetes 集群中进行应用安全管理,则与传统应用安全管理有所不同。本文将详细阐述 Kubernetes 中的应用安全管理方法,以及如何遵循...

    1 年前
  • Web Components : 盒子模型是什么?

    在前端开发中,盒子模型是一个非常重要的概念。盒子模型是指在网页中,每个 HTML 元素都是一个矩形盒子,包括元素的内容(content)、内边距(padding)、边框(border)和外边距(mar...

    1 年前
  • Next.js 中的全局变量的最佳实践

    在前端开发中,我们经常需要使用全局变量来存储和传递应用程序的状态和数据。在 Next.js 中,可以通过一些最佳实践来实现全局变量的使用。 为什么需要全局变量? 全局变量是在整个应用程序中都可访问的变...

    1 年前
  • 解决 Angular 应用中使用 HttpInterceptor 的一些问题

    在 Angular 应用中,HttpInterceptor 可以被用来为 HTTP 请求添加一个中间层,在请求发出前和响应返回后做一些增强处理,尤其是在实现全局处理 CSRF 安全策略和添加 Toke...

    1 年前
  • 响应式设计下如何处理网页图标?

    在响应式设计中,网页图标的处理是一个很重要的问题。网页图标是网站的重要元素之一,通常被用作网页标签页图标、Favicon 和移动设备的应用图标等。在不同的设备上,网页图标需要呈现不同的尺寸和格式,这就...

    1 年前
  • Koa 应用程序中的代码分层技术

    简介 Koa 是一个现代化的 Node.js 开发框架,它旨在提升 Web 应用程序的效率和体验。在开发一个 Koa 应用程序时,为了实现代码的可维护性、可扩展性和可读性,我们需要采用一定的代码分层技...

    1 年前
  • React 测试皆可用 ——Enzyme 测试 React 项目

    前言 在前端开发中,测试是必不可少的一步。它可以帮助我们在开发过程中发现问题,提高代码的可靠性和稳定性。对于 React 项目而言,我们可以使用 Enzyme 来进行测试,它可以帮助我们简化测试过程,...

    1 年前
  • 利用 Flexbox 布局实现响应式的栅格布局

    前言 在前端开发中,最常见的需求就是实现响应式布局。随着移动互联网的普及,各种不同的移动设备屏幕尺寸不断增多,需要开发者能够快速适应各种屏幕尺寸的需求。其中栅格布局是最常用的布局方式之一。

    1 年前
  • 如何在 LESS 中优化 z-index 的规范化?

    在前端开发中,使用 z-index 属性可以控制页面元素的层级关系。但是,如果没有良好的规范化和组织,z-index 会很快变得混乱无章,导致维护成本增加,甚至会出现一些难以解决的 bug。

    1 年前
  • Deno 的 fetch API 出现 "SSL certificate problem: certificate has expired" 解决方法

    问题描述 在使用 Deno 的 fetch API 进行网络请求时,有时会遇到类似以下的错误: ------ -------- --- -------- -------------- --------...

    1 年前
  • 使用 ECMAScript 2015 的 async/await 解决异步编程的烦恼

    在前端开发中,异步编程是非常常见而且重要的。在 JavaScript 中,我们通常使用回调函数、Promise、Generator 等方式来处理异步操作。然而这些方式都有其自己的局限性,例如回调函数容...

    1 年前
  • Mocha 测试框架中如何测试 iOS 应用程序?

    Mocha 测试框架中如何测试 iOS 应用程序? Mocha 是一个强大、灵活的 JavaScript 测试框架。它可以用于测试浏览器、Node.js、React Native 和 Electron...

    1 年前
  • TypeScript 中的声明文件:如何创建和使用声明文件

    什么是 TypeScript 声明文件 TypeScript 声明文件是用来描述 JavaScript 代码库中 API 接口的描述文件,可以让 TypeScript 在编译阶段进行类型检查和编译优化...

    1 年前
  • 解决 Mongoose 无法正确保存布尔类型的问题

    在使用 Mongoose 进行 Node.js 开发时,在保存布尔类型数据时,可能会遇到无法正确保存的问题。这个问题可能由于 Mongoose 的字段类型设置或者数据传输中出现的错误导致。

    1 年前
  • Socket.io 数据库存储的实现及优化

    在实现实时交互的时候,很多开发者会选择 Socket.io 这个库。Socket.io 是一个基于 Node.js 的实时应用程序框架,它提供了简单、快速和可靠的双向数据流通信,支持 WebSocke...

    1 年前
  • 如何通过 SSE 技术实现网页端的即时聊天功能

    引言 SSE (Server-Sent Events) 技术是一种基于 HTTP 协议的服务器推送技术,它可以通过浏览器与服务器端建立持久连接,从而实现服务器端的实时数据推送。

    1 年前
  • Chai 和 Sinon.js:如何测试 JavaScript AJAX 调用

    Chai 和 Sinon.js:如何测试 JavaScript AJAX 调用 在前端开发中,我们需要确保我们的代码能够正确调用后端 API 并处理返回结果。这就需要我们进行 AJAX 请求的测试。

    1 年前
  • MongoDB 中如何处理集合的大小

    MongoDB 是一个非关系型数据库,它以文档为数据存储单位,支持高可扩展性和灵活的数据模型。在使用 MongoDB 时,可能会遇到一些集合大小超过预期的情况,这篇文章将介绍如何处理 MongoDB ...

    1 年前
  • 利用 PM2 优化 Node.js 应用的流量控制

    介绍 随着互联网技术的发展,Node.js 作为一种服务器端运行的 JavaScript 呈现出越来越广泛的应用。Node.js 运行应用的好处是可以非常快速的处理请求,但也需要考虑到流量的控制,以避...

    1 年前
  • React 中如何使用 React-Grid-Layout 实现可拖拽的布局

    在前端开发中,布局是一个不可避免的主题。为了实现灵活、多样的布局效果,我们常常需要依靠一些第三方组件或库。而 React-Grid-Layout 就是其中一个非常实用的工具,它让我们可以轻松地实现可拖...

    1 年前

相关推荐

    暂无文章