首页前端开发JavaScript聊聊JavaScript中的可选 (?.)操作符

聊聊JavaScript中的可选 (?.)操作符

时间2024-01-29 20:06:03发布访客分类JavaScript浏览921
导读:收集整理的这篇文章主要介绍了聊聊JavaScript中的可选 (?. 操作符,觉得挺不错的,现在分享给大家,也给大家做个参考。本篇文章给大家介绍一下JavaScript中的可选 (?. 操作符。有一定的参考价值,有需要的朋友可以参考一下,希...
收集整理的这篇文章主要介绍了聊聊JavaScript中的可选 (?.)操作符,觉得挺不错的,现在分享给大家,也给大家做个参考。本篇文章给大家介绍一下JavaScript中的可选 (?.)操作符。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

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

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

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

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

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

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

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

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

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

很 nice 呀。

语法

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

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 对象:

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

属性

访问存在的属性:

console.LOG(user.homeaddress.country);
     // 中国

访问不存在的属性:

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

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

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

方法

访问存在的方法:

console.log(user.getFirstName());
    

访问不存在的方法:

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

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

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

数组

访问存在的数组:

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

访问不存在的方法:

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

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

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

?? 操作符

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

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

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

需要返回默认值:

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

英文原文地址:https://codingncoepts.COM/javascript/optional-chaining-opeator-javascript/

作者:Ashish Lahoti

更多编程相关知识,请访问:编程入门!!

以上就是聊聊JavaScript中的可选 (?.)操作符的详细内容,更多请关注其它相关文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

操作符

若转载请注明出处: 聊聊JavaScript中的可选 (?.)操作符
本文地址: https://pptw.com/jishu/591538.html
javascript如何定时自动关闭页面 javascript主要的循环有哪些

游客 回复需填写必要信息