JS 里的 ?? 和 || 有啥区别

在JavaScript中,??(空值合并运算符)和 ||([逻辑或运算符)都可以用来处理变量值,但是切记这俩玩意不一样,是有区别的。

??(空值合并运算符)

空值合并运算符 (??)是一个逻辑运算符,当左侧的操作数为 nullundefined 时,返回右侧的操作数;否则,返回左侧的操作数。

let a = null;
let b = 5;
let result = a ?? b; // result 将是 5,因为 a 是 null

let c = 0;
let d = "hello";
let result2 = c ?? d; // result2 将是 0,因为 c 不是 null 或 undefined

||(逻辑或运算符)

逻辑或运算符 (||) 是一个短路逻辑运算符,当左侧的操作数为假值(如 false、0、""、null、undefined 或 NaN)时,返回右侧的操作数;否则,返回左侧的操作数。

let x = 0;
let y = "default";
let result3 = x || y; // result3 将是 "default",因为 0 被视为假值

let z = null;
let w = "hello";
let result4 = z || w; // result4 将是 "hello",因为 null 被视为假值

let result5 = null || undefined || 0 || "";  // 全是假值时,会返回最后一个  ''

区别

假值检查:
  • ?? 只检查 null 或 undefined。
  • || 检查所有假值(false、0、""、null、undefined、NaN)。
类型强制转换:
  • ?? 不会对操作数进行类型转换,它直接返回原始值。
  • || 会进行类型强制转换,如果左侧的操作数可以转换为假值,则返回右侧的操作数。
使用场景:
  • ?? 通常用于设置默认值,当左侧的值可能为 null 或 undefined 时。
  • || 以前常用于设置默认值,但现在推荐使用 ??,因为它更准确地处理了 null 和 undefined 的情况。
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容