空值合并运算符 ?? ,|| 的替代方案

https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/Nullish_coalescinghttps://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Operators/Nullish_coalescing

空值合并运算符在前端中的正确打开方式

在 JavaScript 中,处理"空值默认值"是一个非常高频的需求。为了更精确地控制兜底逻辑,ES2020 引入了 ?? ------ 空值合并运算符(Nullish Coalescing Operator)。

1. ?? 的核心行为

?? 只在左侧的值为 null 或 undefined 时,才会返回右侧的默认值,其余情况保持原值。

javascript 复制代码
const a = null ?? 100  // 100
const b = 0 ?? 100     // 0(不会被误伤)
const c = '' ?? 100    // ''(不会被误伤)
2. 与 || 的关键区别

|| 适用于所有 falsy 值兜底,但会误覆盖 0''false 等有效值;?? 更加精确,只针对真正的空值。

javascript 复制代码
0 || 100      // 100(误覆盖)
0 ?? 100      // 0(正确保留)
'' || 100     // 100(误覆盖)
'' ?? 100     // ''(正确保留)
false || 100  // 100(误覆盖)
false ?? 100  // false(正确保留)
3. 适用场景
  • 需要保留 0、空字符串等合法业务数据

  • 解析流式数据、配置合并、参数默认值、字段回填

  • 避免大量 if (x == null) 判断

  • 提高代码语义清晰度和健壮性

4. 兼容性

?? 在现代浏览器和 Node.js 14+ 环境均被广泛支持,已经是前端项目的主流推荐写法。

5. 注意事项
  • ?? 不能与 && / || 直接混用,需加括号

    javascript 复制代码
    (a || b) ?? c  // 正确
    a || b ?? c    // 报错

总结

?? 让默认值兜底逻辑更精准、安全、不误覆盖业务有效值,是现代 JavaScript 代码中不可或缺的语法能力。

在前端开发中,推荐优先使用 ?? 处理空值合并,使代码更可靠、更易维护。

相关推荐
踢球的打工仔14 分钟前
typescript-类
前端·javascript·typescript
天天打码28 分钟前
Svelte-无虚拟DOM、极致性能的现代高性能Web开发框架!
前端·node.js·vue·svelte
0思必得036 分钟前
[Web自动化] Selenium元素定位
前端·python·selenium·自动化·html
EEEzhenliang1 小时前
CSS知识概括、总结
前端·css
大阳光男孩1 小时前
ElementUI表格懒加载子级更新数据刷新不生效问题
前端·javascript·elementui
wy3136228211 小时前
C#——意框架(结构说明)
前端·javascript·c#
研☆香1 小时前
JS中的三种显示弹窗
开发语言·前端·javascript
俩毛豆1 小时前
HarmonyOS APP开发-一文讲清使用Web组件加载网页的三种方法-《精通HarmonyOS NEXT :鸿蒙App开发入门与项目化实战》读者福利
前端·华为·harmonyos
猛扇赵四那边好嘴.2 小时前
Flutter 框架跨平台鸿蒙开发 - 问答社区应用开发教程
开发语言·javascript·flutter·华为·harmonyos
C_心欲无痕2 小时前
Next.js 路由系统对比:Pages Router vs App Router
开发语言·前端·javascript