|| ?. ?? ??= 4种操作符

JavaScript 中 ||、?.、?? 的含义与用法

一、符号概览

  • || 逻辑或 :返回第一个"真值"(truthy);若都是"假值"(falsy),返回最后一个值。常用于提供默认值与布尔判断。falsy 值包括:false、0、""、null、undefined、NaN
  • ?. 可选链 :安全访问嵌套属性或调用方法;当链中某项为 null/undefined 时,表达式短路返回 undefined 而不报错。
  • ?? 空值合并 :仅当左侧为 null/undefined 时返回右侧默认值;对 0、""、false 等"假值"会原样保留。
  • 相关扩展:??= 空值合并赋值(仅在左侧为 null/undefined 时赋值)。

二、用法与示例

  • || 逻辑或

    • 规则:返回第一个真值;具有短路特性(左侧为真不再求值右侧)。

    • 示例:

      js 复制代码
      const a = 0 || 10;        // 10(0 是 falsy)
      const b = "" || "Hi";     // "Hi"(空字符串是 falsy)
      const c = null || "def";   // "def"
    • 场景:需要把任何 falsy 都替换成默认值的快捷写法。

  • ?. 可选链

    • 规则:访问 obj?.propobj?.[expr]arr?.[index]func?.() 时,若左侧为 null/undefined 则短路返回 undefined

    • 示例:

      js 复制代码
      const user = { profile: { name: "A" } };
      console.log(user?.profile?.age);       // undefined
      console.log(user.settings?.theme);    // undefined
      console.log(user.profile.getName?.()); // undefined(方法不存在不报错)
    • 场景:处理 API 深层结构、可能缺失的属性/方法,避免 Cannot read property... 错误。

  • ?? 空值合并

    • 规则:仅当左侧为 null/undefined 时返回右侧;其他值(含 0、""、false)保留。

    • 示例:

      js 复制代码
      const a = 0 ?? 10;        // 0(保留 0)
      const b = "" ?? "Hello";   // ""(保留空字符串)
      const c = null ?? "def";   // "def"
      const d = false ?? true;   // false(保留 false)
    • 场景:需要区分"未设置(null/undefined)"与"显式假值(0、""、false)"的默认值逻辑。

三、如何选择

  • 需要安全访问可能为 null/undefined 的深层属性或方法:用 ?.
  • 只想在值为 null/undefined 时给默认值,同时保留 0、""、false :用 ??
  • 希望把所有 falsy (如 0、""、false )都替换成默认值:用 ||
  • 需要"仅当缺失才赋值"的简写:用 ??=

四、组合与注意

  • 常见组合:先安全取值,再给默认值,避免报错与误覆盖。

    js 复制代码
    const city = user?.address?.city ?? "未知城市";
  • 与运算优先级:表达式中混用 ??&&/|| 必须用括号明确顺序,否则语法错误。

    js 复制代码
    // 错误:let x = a && b ?? c;
    let x = (a && b) ?? c; // 正确
  • 不能对可选链左侧直接赋值:

    js 复制代码
    obj?.prop = 1; // SyntaxError
  • 浏览器/环境支持提示:?.??ES2020 特性;如需兼容旧环境,请使用 Babel 等转译工具。

相关推荐
计算机学姐6 分钟前
基于SpringBoot的高校体育场馆预约系统【个性化推荐算法+数据可视化统计】
java·vue.js·spring boot·后端·mysql·信息可视化·推荐算法
爱上妖精的尾巴14 分钟前
7-8 WPS JS宏 对象使用实例5--按多字段做多种汇总
javascript·后端·restful·wps·jsa
祎直向前17 分钟前
linuxshell循环,条件分支语句
前端·chrome
LongtengGensSupreme17 分钟前
开放所有跨域 ----前端和后端
前端·后端·ajax·vue·api·jquery
我算哪枝小绿植18 分钟前
react实现日历拖拽效果
前端·react.js·前端框架
白粥21 分钟前
【HTML】文本格式化
前端·javascript·html
爱写程序的小高22 分钟前
npm版本降级、nvm切换node版本、webpack版本与vue版本不一致
前端·npm·node.js
sheji341624 分钟前
【开题答辩全过程】以 基于HTML5的移动端网页设计为例,包含答辩的问题和答案
前端·html·html5
jayaccc24 分钟前
前端缓存全解析:提升性能的关键策略
前端·缓存
只有干货24 分钟前
动态表单组件渲染并采集 展示vue component
javascript·vue.js·ecmascript