空值合并运算符(??)仅在左侧为null或undefined时返回右侧值,否则保留原值;与||不同,它不将0、false、”等falsy值视为“空”;常用于默认值设置、安全读取嵌套属性等场景。

空值合并运算符(??)是 JavaScript 中用于处理 null 或 undefined 的简洁语法,它只在左侧操作数为 null 或 undefined 时,才返回右侧操作数;其他任何“假值”(比如 0、false、'')都会被原样保留。
和逻辑或(||)的区别
很多人容易混淆 ?? 和 ||,关键区别在于判断“假值”的范围:
|| 在左侧为任意“falsy 值”(false、0、''、NaN、null、undefined)时都用右边值 ?? 只有在左侧是 null 或 undefined 时才用右边值,其余都照常返回
例如:
const count = 0;console.log(count || 10); // 10 ← 因为 0 是 falsyconsole.log(count ?? 10); // 0 ← 因为 0 既不是 null 也不是 undefined
常见使用场景
主要用在设置默认值,尤其是处理可能未定义的配置项、API 返回字段或用户输入:
立即学习“Java免费学习笔记(深入)”;
给函数参数设默认值:function greet(name) { name = name ?? 'Guest'; ... } 安全读取嵌套属性:user.profile?.name ?? 'Anonymous'(配合可选链) 处理表单输入:formData.age ?? 18,允许年龄为 0,但没填时才用默认值
注意事项
?? 不能直接和 && 或 || 连用(会报错),必须加括号明确优先级:
✅ 正确:(a ?? b) && c 或 a ?? (b && c) ❌ 错误:a ?? b && c(语法错误)
它从 ES2020 开始支持,现代浏览器和 Node.js 14+ 都可用;如需兼容旧环境,可用 Babel 转译。
基本上就这些。用对了能写出更准确、不易出错的默认值逻辑。
以上就是什么是JavaScript的空值合并运算符?的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1543460.html
微信扫一扫
支付宝扫一扫