这篇文章主要讲解了“JavaScript中的可选 (?.)操作符的使用方法”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript中的可选 (?.)操作符的使用方法”吧!
如何使用null (null
和undefined
)检查访问对象的嵌套属性?假设我们必须从后台的接口访问用户详细信息。
可以使用嵌套的三元运算符 :
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);
// 中国
感谢各位的阅读,以上就是“JavaScript中的可选 (?.)操作符的使用方法”的内容了,经过本文的学习后,相信大家对JavaScript中的可选 (?.)操作符的使用方法这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。