空值合并运算符`??`和逻辑或运算符 `||` 的区别

空值合并运算符 ?? 是 JavaScript 中的一个逻辑操作符,用于处理 nullundefined 的情况。以下是关于的详细介绍:

语法

javascript 复制代码
let result = value1 ?? value2;

在这个语法中,如果 value1 不是 null 也不是 undefined,则 result 的值为 value1;否则,result 的值为 value2

应用场景

  • 提供默认值 :当需要为可能是 nullundefined 的变量提供默认值时,可以使用该运算符。
javascript 复制代码
let username = null;
let defaultUsername = "Guest";
let displayName = username ?? defaultUsername;
console.log(displayName); // 输出: "Guest"
  • 简化代码 :避免使用复杂的逻辑来处理 nullundefined 的情况,使代码更加简洁易读。

与逻辑或运算符 || 的区别

逻辑或运算符 || 会在左侧操作数为假值(如 0''falsenullundefinedNaN 等)时返回右侧操作数;而空值合并运算符 ?? 仅在左侧操作数为 nullundefined 时返回右侧操作数,其他假值会被保留。

javascript 复制代码
let value1 = 0;
let value2 = "Default";
let result1 = value1 ?? value2;
let result2 = value1 || value2;
console.log(result1); // 输出: 0
console.log(result2); // 输出: "Default"

在上述例子中,使用 ?? 运算符时,result10;而使用 || 运算符时,result2value2 的值,因为 || 会把 0 视作假值。

综上所述,空值合并运算符 ?? 在处理只有 nullundefined 的情况时更为准确,能避免误将有效假值替换,提升代码的健壮性。

相关推荐
2401_878454537 小时前
浏览器工作原理
前端·javascript
by__csdn8 小时前
Vue3 setup()函数终极攻略:从入门到精通
开发语言·前端·javascript·vue.js·性能优化·typescript·ecmascript
Luna-player9 小时前
在前端中,<a> 标签的 href=“javascript:;“ 这个是什么意思
开发语言·前端·javascript
lionliu05199 小时前
js的扩展运算符的理解
前端·javascript·vue.js
小草cys9 小时前
项目7-七彩天气app任务7.4.2“关于”弹窗
开发语言·前端·javascript
前端一小卒11 小时前
一个看似“送分”的需求为何翻车?——前端状态机实战指南
前端·javascript·面试
syt_101311 小时前
Object.defineProperty和Proxy实现拦截的区别
开发语言·前端·javascript
长安牧笛11 小时前
儿童屏幕时间管控学习引导系统,核心功能,绑定设备,设时长与时段,识别娱乐,APP超时锁屏,推荐益智内容,生成使用报告,学习达标解锁娱乐
javascript
栀秋66612 小时前
深入浅出链表操作:从Dummy节点到快慢指针的实战精要
前端·javascript·算法
青青很轻_12 小时前
Vue自定义拖拽指令架构解析:从零到一实现元素自由拖拽
前端·javascript·vue.js