巩固一下 JS 可选 (?.)操作符号,原来函数也可以用可选写法,又学到了!

开发 前端
如何使用null (null和undefined)检查访问对象的嵌套属性?假设我们必须从后台的接口访问用户详细信息。

[[404867]]

可选的链接?.操作符用于使用隐式空检查访问嵌套对象属性。

概述

如何使用null (null和undefined)检查访问对象的嵌套属性?假设我们必须从后台的接口访问用户详细信息。

可以使用嵌套的三元运算符 :

  1. const userName = response ? (response.data ? (response.data.user ? response.data.user.name : null) : null) : null

或者使用 if 进行空值检查:

  1. let userName = null
  2. if(response && response.data && response.data.user){ 
  3.   userName = response.data.user.name

或者更好的方法是使它成为一个单行链接的&&条件,像这样:

  1. const userName = response && response.data && response.data.user && response.data.user.name

上述代码的共同之处在于,链接有时会非常冗长,并且变得更难格式化和阅读。这就是 ?.操作符被提出来的原因,我们改下 ?. 重构上面的代码:

  1. const userName = response?.data?.user?.name

很 nice 呀。

语法

?. 语法在ES2020 中被引入,用法如下:

  1. obj.val?.pro  // 如果`val`存在,则返回`obj.val.prop`,否则返回 `undefined`。 
  2.  
  3. obj.func?.(args) // 如果 obj.func 存在,则返回 `obj.func?.(args)`,否则返回 `undefined`。 
  4.  
  5. obj.arr?.[index] // 如果 obj.arr 存在,则返回 `obj.arr?.[index]`,否则返回 `undefined`。 

使用?.操作符

假设我们有一个 user 对象:

  1. const user = { 
  2.   name"前端小智"
  3.   age: 21, 
  4.   homeaddress: { 
  5.     country: "中国" 
  6.   }, 
  7.   hobbies: [{name"敲代码"}, {name"洗碗"}], 
  8.   getFirstName: function(){ 
  9.     return this.name
  10.   } 

属性

访问存在的属性:

  1. console.log(user.homeaddress.country);  
  2. // 中国 

访问不存在的属性:

  1. console.log(user.officeaddress.country);  
  2. // throws error "Uncaught TypeError: Cannot read property 'country' of undefined" 

改用 ?. 访问不存在的属性:

  1. console.log(user.officeaddress?.country);  
  2. // undefined 

方法

访问存在的方法:

  1. console.log(user.getFirstName());  
  2. // 前端小智 

访问不存在的方法:

  1. console.log(user.getLastName());  
  2. // throws error "Uncaught TypeError: user.getLastName is not a function"

改用 ?. 访问不存在的方法:

  1. console.log(user.getLastName?.());  
  2. // "undefined" 

数组

访问存在的数组:

  1. console.log(user.hobbies[0].name);  
  2. // "敲代码" 

访问不存在的方法:

  1. console.log(user.hobbies[3].name);  
  2. // throws error "Uncaught TypeError: Cannot read property 'name' of undefined" 

改用 ?. 访问不存在的数组:

  1. console.log(user.dislikes?.[0]?.name);  
  2. // "undefined" 

?? 操作符

我们知道 ?. 操作符号如果对象不存在,刚返回 undefined,开发中可能不返回 undefined 而是返回一个默认值,这时我们可以使用双问题 ?? 操作符。

有点抽象,直接来一个例子:

  1. const country = user.officeaddress?.country; 
  2. console.log(country); 
  3. // undefined 

需要返回默认值:

  1. const country = user.officeaddress?.country ?? "中国"
  2. console.log(country); 
  3. // 中国 

~完,我是刷碗智,SPA走起来,下期见!

作者:Ashish Lahoti 译者:前端小智 来源:CSS-Tricket

原文:https://codingncoepts.com/javascript/optional-chaining-opeator-javascript/

本文转载自微信公众号「大迁世界」,可以通过以下二维码关注。转载本文请联系大迁世界公众号。

 

责任编辑:武晓燕
相关推荐

2021-05-20 10:22:34

操作符可选链操作符编程技巧

2024-01-16 07:33:02

SwiftTypeScript可选绑定

2022-09-19 08:48:03

项目初始化线程

2021-11-16 12:25:14

jsPPT前端

2020-10-09 10:45:22

语言代码数组

2015-09-02 10:33:54

红包类型optionals

2024-02-06 09:30:25

Figma矩形矩形物理属性

2009-05-11 15:49:02

LinuxUbuntu戴尔

2011-01-21 13:56:44

SendmailSolaris

2023-07-17 09:19:20

CSSCSS 渐变

2010-01-26 14:53:12

2021-12-27 08:45:19

固态硬盘硬盘存储

2024-04-02 09:42:39

2021-01-20 06:29:42

JS工具操作符

2010-08-02 13:55:20

2024-01-17 06:23:35

SwiftTypeScript定义函数

2009-02-19 13:28:08

远程通讯技术及原理Java

2019-10-23 15:53:16

JavaScript可选链对象

2013-04-19 11:24:19

Ubuntu 13.0GNOME桌面

2009-10-28 13:23:52

VB.NET可选参数
点赞
收藏

51CTO技术栈公众号