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

理解JavaScript中的空值合并运算符(??)_javascript es2020

紅蓮之龍
发布: 2025-11-23 18:35:02
原创
182人浏览过
空值合并运算符(??)在JavaScript中用于精确处理null和undefined的默认值赋值,与逻辑或(||)不同,它仅当左侧为null或undefined时返回右侧值,保留0、""等假值;典型应用场景包括配置项设置和API数据处理,如config.timeout ?? 5000;注意不可与&&或||直接混用,需加括号避免语法错误。

理解javascript中的空值合并运算符(??)_javascript es2020

空值合并运算符(??)是 JavaScript ES2020 引入的一个逻辑操作符,用于处理 nullundefined 的默认值赋值场景。它和传统的逻辑或运算符(||)相似,但行为更精确,只在左侧操作数为 nullundefined 时才返回右侧的默认值。

与逻辑或(||)的区别

逻辑或运算符(||)会在左侧为“假值”时使用右侧值。JavaScript 中的假值包括:false0""(空字符串)、nullundefinedNaN

?? 只关心是否为 nullundefined,其他假值如 0 或空字符串都会被保留。

  • 0 || 10 → 返回 10(因为 0 是假值)
  • 0 ?? 10 → 返回 0(因为 0 不是 null 或 undefined)
  • "" || "default" → 返回 "default"
  • "" ?? "default" → 返回 ""
  • null ?? "default" → 返回 "default"
  • undefined ?? "default" → 返回 "default"

典型使用场景

空值合并常用于设置默认配置、处理用户输入或 API 数据中缺失的字段。

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

ChatsNow
ChatsNow

ChatsNow是一款免费的AI写作类浏览器插件,提供智能聊天机器人、智能翻译、智能搜索等工具

ChatsNow 253
查看详情 ChatsNow
const config = {
  timeout: null,
  retries: 0,
  message: ""
};

const finalConfig = {
  timeout: config.timeout ?? 5000,     // null 使用默认值
  retries: config.retries ?? 3,        // 0 被保留
  message: config.message ?? "none"    // 空字符串被保留
};

// 结果:
// { timeout: 5000, retries: 0, message: "" }
登录后复制

注意事项和限制

?? 不能直接与 &&|| 混用而不加括号,否则会抛出语法错误。

  • 正确写法:(user.name ?? "Anonymous") || "Guest"
  • 错误写法:user.name ?? "Anonymous" || "Guest"(语法错误)

这是为了防止逻辑歧义。如果需要组合使用,请用括号明确优先级。

基本上就这些。空值合并让默认值处理更安全、语义更清晰,特别适合处理可能为 0 或空字符串的合法数据。不复杂但容易忽略细节。

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

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

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

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