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

概述

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

  1. const userName = response
  2. ? (response.data
  3. ? (response.data.user
  4. ? response.data.user.name
  5. : null)
  6. : null)
  7. : null;

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

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

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

  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. obj.func?.(args) // 如果 obj.func 存在,则返回 `obj.func?.(args)`,否则返回 `undefined`。
  3. 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. }
  11. }

属性

访问存在的属性:

  1. console.log(user.homeaddress.country);
  2. // 中国
  3. 访问不存在的属性:
  4. console.log(user.officeaddress.country);
  5. // 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. // 中国

需要注意:
此语法所需 es 版本较高,部分低版本es语法不支持。