JavaScript 中的 ?? 与 || 运算符详解

在 JavaScript 开发中,我们经常需要处理默认值或回退值的情况。两个常用的运算符是空值合并运算符(??)和逻辑或运算符(||)。虽然它们看起来功能相似,但实际应用场景却大不相同。

逻辑或运算符 ||

|| 运算符是 JavaScript 中的传统选择,它会返回第一个"真值",如果左侧操作数为假值(如 false、0、""、null、undefined 或 NaN),则返回右侧操作数。

js 复制代码
const name = userName || "默认用户";

问题是什么?当我们明确想使用 0 或空字符串 "" 时,|| 会跳过这些值,因为它们被视为假值。

空值合并运算符 ??

ES2020 引入的 ?? 运算符更加精确,它只在左侧操作数为 null 或 undefined 时才返回右侧操作数。

js 复制代码
const count = userCount ?? 0;

这意味着空字符串和数字 0 会被保留,而不会被默认值替代。

实际对比案例

js 复制代码
// 使用 ||
0 || 10           // 返回 10
"" || "默认文本"   // 返回 "默认文本"
false || true     // 返回 true

// 使用 ??
0 ?? 10           // 返回 0
"" ?? "默认文本"   // 返回 ""
false ?? true     // 返回 false
null ?? "默认值"   // 返回 "默认值"
undefined ?? 42   // 返回 42

如何选择?

  • 当你只想在值为 null 或 undefined 时使用默认值,选择 ??

  • 当你想在任何假值情况下使用默认值,选择 ||

实际应用场景

表单处理时,空字符串可能是有效输入:

js 复制代码
// 更好的选择
const userInput = formValue ?? "默认消息";

// 可能有问题的选择
const userInput = formValue || "默认消息"; // 空字符串会被替换

计数场景中,0 是有效值:

js 复制代码
// 更好的选择
const displayCount = count ?? "无数据";

// 可能有问题的选择
const displayCount = count || "无数据"; // 0 会被替换为"无数据"

结语

?? 和 || 各有用处,关键是了解它们处理假值的差异。?? 只关心 null 和 undefined,而 || 会检查所有假值。根据具体需求选择合适的运算符,可以让代码更精确、更易于维护。希望这篇文章能帮助你更好地理解并运用这两个运算符!

相关推荐
ejinxian3 分钟前
Rust UI 框架GPUI 与 Electron 的对比
前端·javascript·electron
小马哥learn5 分钟前
Vue3 + Electron + Node.js 桌面项目完整开发指南
前端·javascript·electron
涔溪26 分钟前
在 Electron 框架中连接 OPC UA 服务器并读取 PLC 数据
服务器·javascript·electron
前端小咸鱼一条1 小时前
19. React的高阶组件
前端·javascript·react.js
狮子座的男孩1 小时前
js基础:10、函数对象方法(call/apply)、arguments类数组对象、Date对象、Math工具类、包装类、字符串方法、正则表达式
前端·javascript·正则表达式·包装类·字符串方法·arguments·date对象
qq_338032922 小时前
VUE的生命周期钩子,vue2和vue3的生命周期钩子的核心差异
前端·javascript·vue.js
晨非辰2 小时前
《数据结构风云》递归算法:二叉树遍历的精髓实现
c语言·数据结构·c++·人工智能·算法·leetcode·面试
Dream it possible!2 小时前
LeetCode 面试经典 150_链表_LRU 缓存(66_146_C++_中等)(哈希表 + 双向链表)
c++·leetcode·链表·面试
天天向上10242 小时前
在 Vue3 项目中使用 el-tree
javascript·vue.js·elementui
天天向上10242 小时前
vue2 vue3 修改elementUI和elementPlus主题颜色
前端·javascript·elementui