您现在的位置是:亿华云 > IT科技类资讯
巩固一下 JS 可选 (?.)操作符号,原来函数也可以用可选写法,又学到了!
亿华云2025-10-04 04:03:59【IT科技类资讯】5人已围观
简介可选的链接?.操作符用于使用隐式空检查访问嵌套对象属性。概述如何使用null (null和undefined)检查访问对象的嵌套属性?假设我们必须从后台的接口访问用户详细信息。可以使用嵌套的三元运算符
可选的巩固链接?.操作符用于使用隐式空检查访问嵌套对象属性。
概述
如何使用null (null和undefined)检查访问对象的下J选操选写学嵌套属性?假设我们必须从后台的接口访问用户详细信息。
可以使用嵌套的作符三元运算符 :
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;上述代码的号原函数共同之处在于,链接有时会非常冗长,也可用并且变得更难格式化和阅读。法又这就是巩固 ?.操作符被提出来的原因,我们改下 ?下J选操选写学. 重构上面的亿华云计算代码:
const userName = response?.data?.user?.name;很 nice 呀。
语法
?作符. 语法在ES2020 中被引入,用法如下:
obj.val?号原函数.pro // 如果`val`存在,则返回`obj.val.prop`,也可用否则返回 `undefined`。法又 obj.func?巩固.(args) // 如果 obj.func 存在,则返回 `obj.func?下J选操选写学.(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); // 中国~完,我是刷碗智,SPA走起来,下期见!
作者:Ashish Lahoti 译者:前端小智 来源:CSS-Tricket
原文:https://codingncoepts.com/javascript/optional-chaining-opeator-javascript/
本文转载自微信公众号「大迁世界」,可以通过以下二维码关注。转载本文请联系大迁世界公众号。
很赞哦!(18725)
相关文章
- 其次,一般域名注册有一个获取密码的按钮,域名注册商点击后会向您发送密码。在得到域名注册商发送的密码后,将其传输到域名服务提供商网站,然后输入密码,此时域名呈现申请状态。提交申请后,原注册人通常会向您发送一封电子邮件,询问您是否同意转让。此时,您只需点击同意转移按钮,域名注册商就可以成功转移。
- 如何批量给PDF添加水印?
- Redis概念以及底层数据结构
- Redis概念以及底层数据结构
- 5、企业注册国内域名需要证件,其它情况一律不需要证件。
- 打造 Go 语言最快的排序算法
- 12条MySQL优化技巧,提速不止十倍!
- Redis内存淘汰策略,看这一篇就够了!
- 前面这两个步骤都是在本机完成的。到这里还没有涉及真正的域名解析服务器,如果在本机中仍然无法完成域名的解析,就会真正请求域名服务器来解析这个域名了。
- Redis 内存优化在 vivo 的探索与实践