工作中使用这几个新语法符号能起到代码整洁清爽事半功倍的效果那
第一位
??(空值undefined和null处理)
表达式在 ?? 的左侧 运算符求值为undefined或null,返回其右侧
之前常用的解决方法为:
a = a|| '替换值'
存在的问题:将0,false,‘’等一并处理掉了,有时候不满足我们的需求
如后台返回的0对我们来说是需要的,通过||,0也被认为假
而??可以只处理undefined和null2中情况
let user = {
u1: 0,
u2: false,
u3: null,
u4: undefined
u5: '',
}
let u1 = user.u1??'替换值' // 0
let u2 = user.u2 ?? '替换值' // false
let u3 = user.u3 ?? '替换值' // 替换值
let u4 = user.u4 ?? '替换值' // 替换值
let u5 = user.u5 ?? '替换值' // ''
第二位 ?.
Optional chaining(可选链)
?.用户检测不确定的中间节点
let user = {}
let u1 = user.childer.name // TypeError: Cannot read property 'name' of undefined
let u1 = user.childer?.name // undefined
第三位 逻辑运算符和赋值表达式
逻辑运算符和赋值表达式,新特性结合了逻辑运算符(&&,||,??)和赋值表达式而JavaScript已存在的 复合赋值运算符有:
a ||= b
//等价于
a = a || (a = b)
a &&= b
//等价于
a = a && (a = b)
a ??= b
//等价于
a = a ?? (a = b)
:
if(!a){
a = []
}
a.push(1)
通过||= 可以简写为:
(a||=[]).push(1)