Js中?.、??、??=的用法及使用场景

在JavaScript中,我们经常会遇到需要处理可能为空或未定义的变量的情况。这时,如果直接访问对象的属性,往往会导致程序崩溃。为了防止这种情况发生,JavaScript引入了一些新的操作符:可选链操作符(?.)、空值合并操作符(??)和逻辑赋值操作符(??=)。

可选链操作符(?.)

可选链操作符允许我们安全地读取深层次的属性值,而不必每次都检查中间的对象是否存在。例如:

const user = {};
console.log(user?.address?.title); // undefined, 错误未发生

const arr= {
 foo: {
   bar: {
     baz: 42
   }
 },
 xyz: []
};

const value1 = obj?.foo?.bar?.baz; // 如果任何中间属性不存在或为空,value 将为 undefined
//除了对属性的检查,还可以用于对数组下标及函数的检查
const value2 = obj?.xyz?.[0]?.fn?.();
   
// 传统写法
const value1 = obj && obj.foo && obj.foo.bar && obj.foo.bar.baz; // 需要手动检查每个属性
const value2 = obj && obj.xyz && obj.xyz[0] && obj.xyz[0].fn && obj.xyz[0].fn();

使用场景

  • 链式访问对象属性,而不必手动检查每个属性是否存在。

  • 调用可能不存在的函数。

空值合并操作符(??)

空值合并操作符是当左侧的表达式结果为null或undefined时,返回右侧的表达式。例如:

const a = null;
const b = undefined;
const c = 0;
const d = '';
cosnt e = false;

const value1 = a ?? 'default'; // 'default',因为 a 是 null
const value2 = b ?? 'default'; // 'default',因为 b 是 undefined
const value3 = c ?? 'default'; // 0,因为 c 不是 null 或 undefined
const value4 = d ?? 'default'; // '',因为 d 不是 null 或 undefined
const value5 = e ?? 'default'; // false,因为 e 不是 null 或 undefined

//可能存在的传统写法,除了null,undefined, 无法兼容0、''、false的情况,使用时要特别小心
const value1 = a || 'default'; // 'default'
const value2 = b || 'default'; // 'default'
const value3 = c || 'default'; // 'default',因为 0 转布尔类型是 false
const value4 = d || 'default'; // 'default',因为 '' 转布尔类型是 false
const value5 = e || 'default'; // 'default'

使用场景

  • 提供默认值,而不使用 false 值(如空字符串、0 等)。

  • 在处理可能为 null 或 undefined 的变量时,选择性地提供备用值。

逻辑赋值操作符(??=)

当变量为null或undefined时,使用空值合并赋值操作符可以给变量赋一个默认值。例如:

let a = null;
let b = undefined;
let c = 0;

a ??= 'default'; // 'default',因为 a 是 null
b ??= 'default'; // 'default',因为 b 是 undefined
c ??= 'default'; // 0,因为 c 的初始值不是 null 或 undefined

总的来说,这些新的操作符大大增强了JavaScript处理可能为空或未定义的情况的能力,使我们的代码更安全,更易于阅读和维护。


使用场景

  • 在变量没有被赋值或被赋值为 null 或 undefined 时,将默认值分配给变量

这些运算符在处理可能为 null 或 undefined 的值时非常有用,可以简化代码并提高可读性。然而,需要注意的是,它们是在 ECMAScript 2020 标准中引入的,因此在旧版本的 JavaScript 中可能不被支持。

  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值