typescript使用 ?. ?? ??= 運(yùn)算符的方法步驟
可選鏈運(yùn)算符 (?.)
用于訪問可能為 null 或 undefined 的屬性或方法,以避免出現(xiàn)異常錯(cuò)誤。如果使用 . 運(yùn)算符來訪問一個(gè)可能為 null 或 undefined 的值,會(huì)導(dǎo)致運(yùn)行時(shí)錯(cuò)誤。而使用 ?. 運(yùn)算符,如果該值為 null 或 undefined,則表達(dá)式會(huì)短路,返回 undefined,而不會(huì)拋出異常。
例如:
let obj = { foo: { bar: 42 } }; let value = obj?.foo?.bar; // 如果 obj 或 obj.foo 或 obj.foo.bar 為 null 或 undefined,value 將為 undefined,否則為 42
空值合并運(yùn)算符 (??)
用于給定一個(gè)默認(rèn)值,當(dāng)一個(gè)表達(dá)式的值為 null 或 undefined 時(shí),返回默認(rèn)值。如果一個(gè)變量或表達(dá)式的值為 null 或 undefined,使用 ?? 運(yùn)算符可以提供一個(gè)備選值。
例如:
let x = null; let y = x ?? 5; // 如果 x 為 null 或 undefined,y 將為 5,否則為 x 的值
空值合并賦值運(yùn)算符 (??=)
用于將默認(rèn)值賦給一個(gè)變量,當(dāng)該變量的值為 null 或 undefined 時(shí)。如果一個(gè)變量的值為 null 或 undefined,可以使用 ??= 運(yùn)算符將一個(gè)默認(rèn)值賦給該變量。
例如:
let x = null; x ??= 5; // 如果 x 為 null 或 undefined,將把 5 賦給 x
??和 ||比較相似
?? 和 || 區(qū)別
假值:false、0、空字符串、null、undefined 等
?? 判斷左側(cè)操作數(shù)為null或undefined時(shí),返回右側(cè)操作數(shù)
|| 判斷左側(cè)操作數(shù)為’假值'時(shí),返回右側(cè)操作數(shù)
let a:any; let b = '1111'; let c = null; let d:any = 0; let e; e ??= a?.b ?? c ?? d?.a ?? b; a?.b:這是可選鏈運(yùn)算符 ?. 的使用,它嘗試訪問變量 a 的屬性 b。如果 a 為 null 或 undefined,則表達(dá)式返回 undefined。 a?.b ?? c:這是空值合并運(yùn)算符 ?? 的使用,它判斷左側(cè)操作數(shù) a?.b 是否為 null 或 undefined。如果是,則返回右側(cè)操作數(shù) c 的值。否則,返回左側(cè)操作數(shù) a?.b 的值。 a?.b ?? c ?? d?.a:繼續(xù)使用空值合并運(yùn)算符 ??,判斷前一個(gè)表達(dá)式的結(jié)果 a?.b ?? c 是否為 null 或 undefined。如果是,則返回右側(cè)操作數(shù) d?.a 的值。否則,返回前一個(gè)表達(dá)式的結(jié)果。 a?.b ?? c ?? d?.a ?? b:再次使用空值合并運(yùn)算符 ??,判斷前一個(gè)表達(dá)式的結(jié)果 a?.b ?? c ?? d?.a 是否為 null 或 undefined。如果是,則返回右側(cè)操作數(shù) b 的值。否則,返回前一個(gè)表達(dá)式的結(jié)果。 根據(jù)上述表達(dá)式的邏輯,以下是對(duì)應(yīng)的執(zhí)行過程: a 的值為 undefined。 a?.b 的結(jié)果為 undefined。 a?.b ?? c 的結(jié)果為 null,因?yàn)樽髠?cè)操作數(shù)為 undefined,右側(cè)操作數(shù)為 null。 a?.b ?? c ?? d?.a 的結(jié)果為 0,因?yàn)樽髠?cè)操作數(shù)為 null,右側(cè)操作數(shù)為 d?.a,而 d 的值為 0。 a?.b ?? c ?? d?.a ?? b 的結(jié)果為 '1111',因?yàn)樽髠?cè)操作數(shù)為 0,右側(cè)操作數(shù)為 '1111'。 最終,變量 e 的值被賦為 '1111'。
到此這篇關(guān)于typescript使用 ?. ?? ??= 運(yùn)算符的方法步驟的文章就介紹到這了,更多相關(guān)typescript運(yùn)算符內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript asp.net 獲取當(dāng)前超鏈接中的文本
今天用到,不會(huì)。網(wǎng)上找到一個(gè)方法,趕快記下來??梢垣@取超鏈接的鏈接文本。2009-04-04javascript使用Blob對(duì)象實(shí)現(xiàn)的下載文件操作示例
這篇文章主要介紹了javascript使用Blob對(duì)象實(shí)現(xiàn)的下載文件操作,結(jié)合實(shí)例形式分析了javascript使用Blob對(duì)象下載文件相關(guān)原理、操作技巧與注意事項(xiàng),需要的朋友可以參考下2020-04-04js獲取URL的參數(shù)的方法(getQueryString)示例
getQueryString方法默認(rèn)返回的是 string如果是int類型,則JS使用的時(shí)候,要進(jìn)行轉(zhuǎn)換一下,下面有個(gè)不錯(cuò)的示例,大家可以參考下2013-09-09JavaScript DOM節(jié)點(diǎn)添加示例
本節(jié)為大家介紹下JavaScript DOM節(jié)點(diǎn)添加,將node里面的str放到h1段落中使之成為h1的新段落2014-07-07Uniapp?實(shí)現(xiàn)全民分銷功能原理解析
這篇文章主要介紹了Uniapp?實(shí)現(xiàn)全民分銷功能,本篇文章主要介紹全民分銷功能實(shí)現(xiàn)原理,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06WebGL學(xué)習(xí)教程之Three.js學(xué)習(xí)筆記(第一篇)
Three.js是一個(gè)js的開源框架,它把webgl的所有東西都封裝好了,我們不再需要去了解webgl那些比較麻煩的細(xì)節(jié),直接在此框架上進(jìn)行開發(fā),既方便,又快捷,而且很容易就能學(xué)習(xí),感興趣的朋友跟隨小編一起看看吧2019-04-04利用JavaScript實(shí)現(xiàn)放鞭炮動(dòng)畫效果
談及過年,最先讓人想到的就是,噼里啪啦的鞭炮聲。本文將利用JavaScript實(shí)現(xiàn)一個(gè)簡(jiǎn)單的放鞭炮動(dòng)畫效果,感興趣的小伙伴可以了解一下2023-01-01