本篇文章给大家介绍一下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