JavaScript 中的 `||` 和 `??`

||?? 都是 JavaScript 中的逻辑运算符,但它们有不同的用途和行为。

  1. ||(逻辑或)运算符

    • 用途:用来检查多个表达式,返回第一个真值(truthy)表达式。
    • 行为:当遇到第一个真值(truthy)表达式时,返回该表达式。如果没有真值表达式,则返回最后一个表达式。
    • 真值(truthy)和假值(falsy) :在 JavaScript 中,以下值被视为假值(falsy):false0""(空字符串)、nullundefined、和 NaN。所有其他值都被视为真值(truthy)。
    javascript 复制代码
    let a = 0;
    let b = null;
    let c = 'Hello';
    let result = a || b || c; // result 是 'Hello',因为这是第一个真值(truthy)表达式。
  2. ??(空值合并)运算符

    • 用途 :用来返回第一个不为 nullundefined 的操作数。
    • 行为 :当遇到第一个不为 nullundefined 的操作数时,返回该操作数。如果所有操作数都是 nullundefined,则返回最后一个操作数。
    javascript 复制代码
    let a = 0;
    let b = null;
    let c = 'Hello';
    let result = a ?? b ?? c; // result 是 0,因为 0 不为 null 或 undefined。

关键区别

  • || 会返回第一个真值(truthy)表达式,因此它可能会返回一些在逻辑上为假值(falsy)的值,例如 0""false,因为这些值在 || 运算符中被视为假值。
  • ?? 只会忽略 nullundefined,因此它会返回第一个不为 nullundefined 的值,即使该值是其他假值(falsy),如 0""

例子对比

javascript 复制代码
let a = 0;
let b = '';
let c = 'default';

// 使用 || 运算符
let result1 = a || b || c; // result1 是 'default',因为 0 和 '' 都是 falsy 值。

// 使用 ?? 运算符
let result2 = a ?? b ?? c; // result2 是 0,因为 0 不为 null 或 undefined。

选择哪一个运算符取决于你想要的具体行为。如果你希望忽略所有假值(falsy),使用 ||。如果你只希望忽略 nullundefined,使用 ??

相关推荐
badhope4 小时前
Mobile-Skills:移动端技能可视化的创新实践
开发语言·人工智能·git·智能手机·github
码云数智-园园5 小时前
微服务架构下的分布式事务:在一致性与可用性之间寻找平衡
开发语言
hpoenixf5 小时前
2026 年前端面试问什么
前端·面试
还是大剑师兰特6 小时前
Vue3 中的 defineExpose 完全指南
前端·javascript·vue.js
C++ 老炮儿的技术栈6 小时前
volatile使用场景
linux·服务器·c语言·开发语言·c++
hz_zhangrl6 小时前
CCF-GESP 等级考试 2026年3月认证C++一级真题解析
开发语言·c++·gesp·gesp2026年3月·gespc++一级
泯泷6 小时前
阶段一:从 0 看懂 JSVMP 架构,先在脑子里搭出一台最小 JSVM
前端·javascript·架构
Liu628886 小时前
C++中的工厂模式高级应用
开发语言·c++·算法
IT猿手6 小时前
基于控制障碍函数的多无人机编队动态避障控制方法研究,MATLAB代码
开发语言·matlab·无人机·openclaw·多无人机动态避障路径规划·无人机编队
AI科技星6 小时前
全尺度角速度统一:基于 v ≡ c 的纯推导与验证
c语言·开发语言·人工智能·opencv·算法·机器学习·数据挖掘