||
和 ??
都是 JavaScript 中的逻辑运算符,但它们有不同的用途和行为。
-
||
(逻辑或)运算符:- 用途:用来检查多个表达式,返回第一个真值(truthy)表达式。
- 行为:当遇到第一个真值(truthy)表达式时,返回该表达式。如果没有真值表达式,则返回最后一个表达式。
- 真值(truthy)和假值(falsy) :在 JavaScript 中,以下值被视为假值(falsy):
false
、0
、""
(空字符串)、null
、undefined
、和NaN
。所有其他值都被视为真值(truthy)。
javascriptlet a = 0; let b = null; let c = 'Hello'; let result = a || b || c; // result 是 'Hello',因为这是第一个真值(truthy)表达式。
-
??
(空值合并)运算符:- 用途 :用来返回第一个不为
null
或undefined
的操作数。 - 行为 :当遇到第一个不为
null
或undefined
的操作数时,返回该操作数。如果所有操作数都是null
或undefined
,则返回最后一个操作数。
javascriptlet a = 0; let b = null; let c = 'Hello'; let result = a ?? b ?? c; // result 是 0,因为 0 不为 null 或 undefined。
- 用途 :用来返回第一个不为
关键区别
||
会返回第一个真值(truthy)表达式,因此它可能会返回一些在逻辑上为假值(falsy)的值,例如0
、""
或false
,因为这些值在||
运算符中被视为假值。??
只会忽略null
和undefined
,因此它会返回第一个不为null
或undefined
的值,即使该值是其他假值(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),使用 ||
。如果你只希望忽略 null
和 undefined
,使用 ??
。