首页 > web前端 > js教程 > 正文

什么是JavaScript的空值合并运算符?

幻影之瞳
发布: 2025-12-18 09:19:44
原创
944人浏览过
空值合并运算符(??)仅在左侧为null或undefined时返回右侧值,否则保留原值;与||不同,它不将0、false、''等falsy值视为“空”;常用于默认值设置、安全读取嵌套属性等场景。

什么是javascript的空值合并运算符?

空值合并运算符(??)是 JavaScript 中用于处理 nullundefined 的简洁语法,它只在左侧操作数为 nullundefined 时,才返回右侧操作数;其他任何“假值”(比如 0false'')都会被原样保留。

和逻辑或(||)的区别

很多人容易混淆 ??||,关键区别在于判断“假值”的范围:

  • || 在左侧为任意“falsy 值”(false0''NaNnullundefined)时都用右边值
  • ?? 只有在左侧是 nullundefined 时才用右边值,其余都照常返回

例如:

const count = 0;
console.log(count || 10);   // 10 ← 因为 0 是 falsy
console.log(count ?? 10);   // 0 ← 因为 0 既不是 null 也不是 undefined
登录后复制

常见使用场景

主要用在设置默认值,尤其是处理可能未定义的配置项、API 返回字段或用户输入:

立即学习Java免费学习笔记(深入)”;

Veed AI Voice Generator
Veed AI Voice Generator

Veed推出的AI语音生成器

Veed AI Voice Generator 119
查看详情 Veed AI Voice Generator
  • 给函数参数设默认值:function greet(name) { name = name ?? 'Guest'; ... }
  • 安全读取嵌套属性:user.profile?.name ?? 'Anonymous'(配合可选链)
  • 处理表单输入:formData.age ?? 18,允许年龄为 0,但没填时才用默认值

注意事项

?? 不能直接和 &&|| 连用(会报错),必须加括号明确优先级:

  • ✅ 正确:(a ?? b) && ca ?? (b && c)
  • ❌ 错误:a ?? b && c(语法错误)

它从 ES2020 开始支持,现代浏览器和 Node.js 14+ 都可用;如需兼容旧环境,可用 Babel 转译。

基本上就这些。用对了能写出更准确、不易出错的默认值逻辑。

以上就是什么是JavaScript的空值合并运算符?的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号