JavaScript空值合并运算符??使用场景

 更新时间:2025年09月05日 08:50:13   作者:掘铁  
这篇文章主要介绍了JavaScript空值合并运算符??的相关资料,??是一个js逻辑操作符,当左侧的操作数为null或者undefined时,返回其右侧数,否则返回左侧数,文中通过代码介绍的非常详细,需要的朋友可以参考下

一、核心概念

  1. 作用
    当左侧表达式为 nullundefined 时,返回右侧的默认值;否则返回左侧的值。

  2. 与 || 的区别

    • || 会对 所有假值(如 0''falseNaN)触发默认值。
    • ?? 仅对 nullundefined 触发默认值,保留其他假值的语义。
    console.log(0 || 5);    // 5(0 是假值)
    console.log(0 ?? 5);    // 0(0 不是 null/undefined)
    

二、语法规则

leftExpr ?? rightExpr
  • 短路特性:若 leftExpr 不是 null/undefined,直接返回左侧值,不计算右侧。
  • 优先级:低于 ||&&,但高于三元运算符 ? :。建议用 () 明确优先级。

三、使用场景

1. 变量默认值

const userInput = null;
const name = userInput ?? "Anonymous"; // "Anonymous"

2. 函数参数默认值

function greet(message) {
  const text = message ?? "Hello";
  console.log(text);
}
greet(null);    // "Hello"
greet(undefined); // "Hello"
greet("");      // ""(保留空字符串)

3. 对象属性安全访问

const config = {
  apiUrl: null,
  timeout: 0
};

const url = config.apiUrl ?? "https://default.api";
const timeout = config.timeout ?? 5000; // 0 被保留

4. 结合可选链?.使用

const user = {
  profile: null
};
const username = user?.profile?.name ?? "Guest"; // "Guest"

四、进阶用法

1. 多级空值合并

const a = null;
const b = undefined;
const c = "Fallback";
const result = a ?? b ?? c; // "Fallback"

2. 与解构赋值结合

const settings = { theme: null };
const { theme = "light", fontSize = 16 } = settings;
// theme 使用 ?? 逻辑,fontSize 使用 = 默认值

3. 动态默认值

let defaultPort;
const port = process.env.PORT ?? (defaultPort = 3000);

五、注意事项

  1. 不可直接用于未声明的变量

    // 错误示例(需确保变量已声明)
    const value = undeclaredVar ?? 10; // ReferenceError
    
  2. 与 || 混用时的优先级

    const a = null || undefined ?? "default"; // SyntaxError
    const b = (null || undefined) ?? "default"; // "default"
    
  3. 浏览器兼容性

    • 支持 ES2020+ 的环境(Chrome 80+, Firefox 72+, Node.js 14+)。
    • 旧环境需通过 Babel 插件 @babel/plugin-proposal-nullish-coalescing-operator 转译。

六、性能优化

  • 避免重复计算:若右侧是复杂表达式,用函数封装避免副作用。
    const value = input ?? computeDefault(); // computeDefault() 仅在需要时执行
    

七、替代方案(旧代码兼容)

// 使用三元运算符模拟 ??
const value = (left !== null && left !== undefined) ? left : right;

总结

运算符触发默认值的条件适用场景
??nullundefined保留其他假值(如 0''
``

掌握 ?? 能显著提升代码可读性,尤其在处理 API 响应、配置项等场景时,能更精准地控制默认值逻辑。

到此这篇关于JavaScript空值合并运算符??使用场景的文章就介绍到这了,更多相关js空值合并运算符??内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • js求数组最大值的八种具体实现方法

    js求数组最大值的八种具体实现方法

    数组如何求最大值,想必很多的朋友都不会吧,下面这篇文章主要给大家介绍了关于使用js求数组最大值的八种方法具体实现的相关资料,文中给出了详细的代码示例,需要的朋友可以参考下
    2023-09-09
  • 小程序获取手机验证码倒计时的方法

    小程序获取手机验证码倒计时的方法

    这篇文章主要为大家详细介绍了小程序获取手机验证码倒计时的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下<BR>
    2022-08-08
  • Javascript & DHTML上传文件控件

    Javascript & DHTML上传文件控件

    首先来做一个实例,批量上传的UI控件。以后一般做的示例也是以UI控件为主的。都是封装成Object或者用Function封装成"Class"类。
    2008-07-07
  • 原生js实现弹跳小球

    原生js实现弹跳小球

    这篇文章主要为大家详细介绍了原生js实现弹跳小球,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-09-09
  • JavaScript 作用域链解析

    JavaScript 作用域链解析

    一直对Js的作用域有点迷糊,今天偶然读到Javascript权威指南,立马被吸引住了,写的真不错。我看的是第六版本,相当的厚,大概1000多页,Js博大精深,要熟悉精通需要大毅力大功夫。谢谢心得吧
    2014-11-11
  • 浅析2种JavaScript继承方式

    浅析2种JavaScript继承方式

    这篇文章主要介绍了2种JavaScript主要继承方式,一种是通过原型的方式,一种是通过借用call&apply的构造函数方式,感兴趣的小伙伴们可以参考一下
    2015-12-12
  • JavaScript canvas实现加载图片

    JavaScript canvas实现加载图片

    这篇文章主要为大家详细介绍了JavaScript canvas实现加载图片,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-08-08
  • JavaScript Reduce使用详解

    JavaScript Reduce使用详解

    这篇文章主要介绍了JavaScript Reduce使用的相关资料,帮助大家更好的理解和学习使用JavaScript,感兴趣的朋友可以了解下
    2021-03-03
  • splitChunks精细控制代码分割降低包大小

    splitChunks精细控制代码分割降低包大小

    这篇文章主要为大家介绍了如何使用splitChunks精细控制代码分割来实现降低包大小的示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • JavaScript动态加载样式表的方法

    JavaScript动态加载样式表的方法

    这篇文章主要介绍了JavaScript动态加载样式表的方法,涉及javascript操作样式表的技巧,非常具有实用价值,需要的朋友可以参考下
    2015-03-03

最新评论