前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >简单复习下 JS 可选 (?.)操作符号,原来函数也可以用可选写法

简单复习下 JS 可选 (?.)操作符号,原来函数也可以用可选写法

作者头像
前端达人
发布2021-07-16 17:01:08
5450
发布2021-07-16 17:01:08
举报
文章被收录于专栏:前端达人
可选的链接?.操作符用于使用隐式空检查访问嵌套对象属性。

概述

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

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

代码语言:javascript
复制
const userName = response ? (response.data ? (response.data.user ? response.data.user.name : null) : null) : null;

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

代码语言:javascript
复制
let userName = null;
if(response && response.data && response.data.user){
  userName = response.data.user.name;
}

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

代码语言:javascript
复制
const userName = response && response.data && response.data.user && response.data.user.name;

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

代码语言:javascript
复制
const userName = response?.data?.user?.name;

很 nice 呀。

语法

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

代码语言:javascript
复制
obj.val?.pro  // 如果`val`存在,则返回`obj.val.prop`,否则返回 `undefined`。

obj.func?.(args) // 如果 obj.func 存在,则返回 `obj.func?.(args)`,否则返回 `undefined`。

obj.arr?.[index] // 如果 obj.arr 存在,则返回 `obj.arr?.[index]`,否则返回 `undefined`。

使用?.操作符

假设我们有一个 user 对象:

代码语言:javascript
复制
const user = {
  name: "前端小智",
  age: 21,
  homeaddress: {
    country: "中国"
  },
  hobbies: [{name: "敲代码"}, {name: "洗碗"}],
  getFirstName: function(){
    return this.name;
  }
}
属性

访问存在的属性:

代码语言:javascript
复制
console.log(user.homeaddress.country); 
// 中国

访问不存在的属性:

代码语言:javascript
复制
console.log(user.officeaddress.country); 
// throws error "Uncaught TypeError: Cannot read property 'country' of undefined"

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

代码语言:javascript
复制
console.log(user.officeaddress?.country); 
// undefined
方法

访问存在的方法:

代码语言:javascript
复制
console.log(user.getFirstName()); 
// 前端小智

访问不存在的方法:

代码语言:javascript
复制
console.log(user.getLastName()); 
// throws error "Uncaught TypeError: user.getLastName is not a function";

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

代码语言:javascript
复制
console.log(user.getLastName?.()); 
// "undefined"

数组

访问存在的数组:

代码语言:javascript
复制
console.log(user.hobbies[0].name); 
// "敲代码"

访问不存在的方法:

代码语言:javascript
复制
console.log(user.hobbies[3].name); 
// throws error "Uncaught TypeError: Cannot read property 'name' of undefined"

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

代码语言:javascript
复制
console.log(user.dislikes?.[0]?.name); 
// "undefined"

?? 操作符

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

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

代码语言:javascript
复制
const country = user.officeaddress?.country;
console.log(country);
// undefined

需要返回默认值:

代码语言:javascript
复制
const country = user.officeaddress?.country ?? "中国";
console.log(country);
// 中国

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


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

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

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2021-06-20,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 前端达人 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 概述
  • 语法
  • 使用?.操作符
    • 属性
      • 方法
      • 数组
      • ?? 操作符
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档