可选链操作符(?.)允许安全访问嵌套属性,避免因null或undefined导致的错误;空值合并运算符(??)则在左侧为nullish时提供默认值,二者结合可简洁处理数据读取与默认赋值。

JavaScript中的可选链操作符(?.)和空值合并运算符(??)是ES2020引入的两个实用语法,用于更安全、简洁地处理可能为null或undefined的情况。
可选链操作符(?.)
可选链允许你安全访问嵌套对象的深层属性,而无需每次都检查每一层是否存在。
如果访问的属性或调用的方法所在的对象为null或undefined,表达式会立即返回undefined,而不是抛出错误。
常见使用场景:访问嵌套属性:obj?.a?.b?.c 调用可能不存在的方法:obj?.method?.() 数组项访问:arr?.[0] 动态属性访问:obj?.[key]
例如:
立即学习“Java免费学习笔记(深入)”;
const user = { profile: { name: "Alice" } };console.log(user?.profile?.name); // "Alice"console.log(user?.settings?.theme); // undefined,不报错
空值合并运算符(??)
空值合并用于在左侧操作数为null或undefined时,返回右侧的默认值。它不会因为0、false、空字符串而触发默认值,只关注nullish值。
这与逻辑或(||)不同,||会在左侧为“假值”时就使用右侧值。
示例对比:
const count1 = 0 || 10; // 10(因为0是假值)const count2 = 0 ?? 10; // 0(因为0不是nullish)const theme1 = "" || "dark"; // "dark"const theme2 = "" ?? "dark"; // ""const value = null ?? "default"; // "default"
结合使用场景
这两个操作符经常一起使用,用来处理复杂但常见的数据读取和默认赋值逻辑。
比如从API返回的数据中获取用户偏好设置:
const theme = user?.preferences?.theme ?? "light";
这行代码的意思是:尝试安全获取theme,如果路径不存在或值为null/undefined,则使用”light”作为默认主题。
基本上就这些。合理使用?.和??能让代码更健壮,减少防御性判断的冗余,提升可读性。
以上就是JavaScript中的可选链操作符与空值合并运算符的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1535272.html
微信扫一扫
支付宝扫一扫