js 空值合并操作符(??)

在 JavaScript 里,空值合并操作符(??)是一个逻辑操作符。当左侧操作数为 null 或者 undefined 时,它会返回右侧操作数;反之,则返回左侧操作数。下面为你详细介绍其使用方法与示例。

基本语法

javascript

ruby 复制代码
leftExpr ?? rightExpr

代码示例

javascript

ini 复制代码
// 示例 1:左侧为 null
const value1 = null;
const result1 = value1 ?? 'default value';
console.log(result1); // 输出: 'default value'

// 示例 2:左侧为 undefined
const value2 = undefined;
const result2 = value2 ?? 'default value';
console.log(result2); // 输出: 'default value'

// 示例 3:左侧为其他值
const value3 = 0;
const result3 = value3 ?? 'default value';
console.log(result3); // 输出: 0

const value4 = false;
const result4 = value4 ?? 'default value';
console.log(result4); // 输出: false

const value5 = '';
const result5 = value5 ?? 'default value';
console.log(result5); // 输出: ''

与逻辑或操作符(||)的区别

逻辑或操作符(||)在左侧操作数为假值(如 0false'' 等)时,就会返回右侧操作数;而空值合并操作符(??)仅在左侧操作数为 null 或者 undefined 时,才会返回右侧操作数。示例如下:

javascript

ini 复制代码
// 使用逻辑或操作符
const value6 = 0;
const result6 = value6 || 'default value';
console.log(result6); // 输出: 'default value'

// 使用空值合并操作符
const value7 = 0;
const result7 = value7 ?? 'default value';
console.log(result7); // 输出: 0

空值合并操作符的链式使用

你可以链式使用空值合并操作符,以此来检查多个可能为 nullundefined 的值。示例如下:

javascript

ini 复制代码
const a = null;
const b = undefined;
const c = 'valid value';
const result = a ?? b ?? c;
console.log(result); // 输出: 'valid value'

通过这些示例能够看出,空值合并操作符在处理可能为 nullundefined 的值时非常实用,能让你轻松地提供默认值。

相关推荐
怎么吃不饱捏20 分钟前
vue3+vite,引入阿里巴巴svg图标,自定义大小颜色
前端·javascript·vue.js
南玖i2 小时前
vue3 通过 Vue3DraggableResizable实现拖拽弹窗,可修改大小
前端·javascript·vue.js
YAY_tyy2 小时前
Three.js 开发实战教程(五):外部 3D 模型加载与优化实战
前端·javascript·3d·three.js
Zuckjet_5 小时前
开启 3D 之旅 - 你的第一个 WebGL 三角形
前端·javascript·3d·webgl
bitbitDown7 小时前
四年前端分享给你的高效开发工具库
前端·javascript·vue.js
YAY_tyy7 小时前
【JavaScript 性能优化实战】第六篇:性能监控与自动化优化
javascript·性能优化·自动化
gnip8 小时前
实现AI对话光标跟随效果
前端·javascript
闭着眼睛学算法9 小时前
【华为OD机考正在更新】2025年双机位A卷真题【完全原创题解 | 详细考点分类 | 不断更新题目 | 六种主流语言Py+Java+Cpp+C+Js+Go】
java·c语言·javascript·c++·python·算法·华为od
烛阴9 小时前
【TS 设计模式完全指南】构建你的专属“通知中心”:深入观察者模式
javascript·设计模式·typescript
lumi.10 小时前
Vue.js 从入门到实践1:环境搭建、数据绑定与条件渲染
前端·javascript·vue.js