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

JavaScript中的可选链操作符(?.)和空值合并运算符(??)是ES2020引入的两个实用语法,用于更安全、简洁地处理可能为null或undefined的情况。
可选链允许你安全访问嵌套对象的深层属性,而无需每次都检查每一层是否存在。
如果访问的属性或调用的方法所在的对象为null或undefined,表达式会立即返回undefined,而不是抛出错误。
常见使用场景:例如:
立即学习“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中的可选链操作符与空值合并运算符的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号