?? // ?. // ||=新語(yǔ)法符號(hào)的使用

工作中使用這幾個(gè)新語(yǔ)法符號(hào)能起到代碼整潔清爽事半功倍的效果那

第一位

??(空值undefined和null處理)
表達(dá)式在 ?? 的左側(cè) 運(yùn)算符求值為undefined或null,返回其右側(cè)
之前常用的解決方法為:
a = a|| '替換值'
存在的問(wèn)題:將0,false,‘’等一并處理掉了,有時(shí)候不滿足我們的需求
如后臺(tái)返回的0對(duì)我們來(lái)說(shuō)是需要的,通過(guò)||,0也被認(rèn)為假
而??可以只處理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(可選鏈)
?.用戶檢測(cè)不確定的中間節(jié)點(diǎn)

let user = {}
let u1 = user.childer.name // TypeError: Cannot read property 'name' of undefined
let u1 = user.childer?.name // undefined

第三位 邏輯運(yùn)算符和賦值表達(dá)式

邏輯運(yùn)算符和賦值表達(dá)式,新特性結(jié)合了邏輯運(yùn)算符(&&,||,??)和賦值表達(dá)式而JavaScript已存在的 復(fù)合賦值運(yùn)算符有:

a ||= b
//等價(jià)于
a = a || (a = b)

a &&= b
//等價(jià)于
a = a && (a = b)

a ??= b
//等價(jià)于
a = a ?? (a = b)

??:
if(!a){
  a = []
}
a.push(1)
通過(guò)||= 可以簡(jiǎn)寫(xiě)為:
(a||=[]).push(1)
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容