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

本篇文章给大家介绍一下javascript中的可选 (?.)操作符。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

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

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

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

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

登录后复制

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

立即学习“Java免费学习笔记(深入)”;

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中的可选 (?.)操作符的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2711957.html

(0)
上一篇 2025年3月7日 21:08:22
下一篇 2025年3月6日 05:50:21

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • java和javascript一样么

    java和javascript不一样,区别为:1、Java被广泛应用于PC端、手机端等,JavaScript则用于嵌入文本到HTML页面;2、Javascript是脚本语言;而Java是新一代面向对象的程序设计语言。 本教程操作环境:win…

    2025年3月7日
    200
  • javascript中window.close如何不提示弹窗

    在javascript中,可以在window.close前添加“window.opener=null;window.open(”,’_self’);”语句设置不提示弹窗。window.opener引用的是…

    2025年3月7日
    200
  • text/javascript有什么用

    在javascript中,text/javascript的作用是告知浏览器按照JavaScript来解析,IE浏览器默认的就是javascript,但是别的浏览器就不一定,可以防止浏览器使用别的来解析和版本兼容问题。 本教程操作环境:win…

    2025年3月7日
    200
  • javascript主要的循环有哪些

    javascript主要的循环有:1、for循环;2、“for…in”循环;3、map方法;4、forEach循环;5、filter过滤循环;6、Object.keys遍历对象的属性。 本教程操作环境:windows7系统、ja…

    2025年3月7日
    200
  • javascript定时器怎么停止

    在javascript中,可以使用clearInterval方法使定时器停止,语法“clearInterval(由setInterval方法设置的timeout)”,该方法的参数必须是由setInterval返回的ID值。 本教程操作环境:…

    2025年3月7日
    200
  • javascript怎么设置渐变色

    在javascript中,可以使用style对象属性设置渐变色,语法格式为“元素对象.style.backgroundImage=’linear-gradient(角度,颜色,颜色)’”;Style对象代表一个单独的…

    2025年3月7日
    200
  • JavaScript中如何加入超链接

    在javascript中,可以使用link方法加入超链接,语法格式为“要操作的字符串/对象.link(url地址)”。“link()”方法用于把字符串显示为超链接。该方法返回加了“”标签的字符串。 本教程操作环境:windows7系统、ja…

    2025年3月7日
    200
  • javascript怎么定义数组长度

    在javascript中,可以使用length属性定义数组长度,语法格式为“arrayObject.length”。对于那些具有连续元素,而且以元素0开始的常规数组而言,属性length声明了数组中的元素的个数。 本教程操作环境:windo…

    2025年3月7日
    200
  • javascript中的引用类型是什么

    javascript中的引用类型是:1、Object类型;2、Function类型;3、Array类型;4、RegExp类型;5、Date类型;6、基本包装类型;7、及单体内置对象(Global、Math)。 本教程操作环境:windows…

    2025年3月7日
    200
  • JavaScript中DOM的含义是什么

    在javascript中,DOM的含义是文档对象模型,DOM提供了对文档的结构化的表述,并定义了一种方式可以使从程序中对该结构进行访问,从而改变文档的结构,样式和内容。 本教程操作环境:windows7系统、javascript1.8.5版…

    2025年3月7日
    200

发表回复

登录后才能评论