日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

【ES11(2020)】可选链操作符和空值合并运算符

發(fā)布時(shí)間:2025/3/15 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 【ES11(2020)】可选链操作符和空值合并运算符 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

可選鏈操作符 Optional chaining

可選鏈操作符( ?. )允許讀取位于連接對(duì)象鏈深處的屬性的值,而不必明確驗(yàn)證鏈中的每個(gè)引用是否有效。?.操作符的功能類似于.鏈?zhǔn)讲僮鞣?#xff0c;不同之處在于,在引用為空(nullish) (null或者 undefined) 的情況下不會(huì)引起錯(cuò)誤,該表達(dá)式短路返回值是 undefined。與函數(shù)調(diào)用一起使用時(shí),如果給定的函數(shù)不存在,則返回 undefined。

當(dāng)嘗試訪問(wèn)可能不存在的對(duì)象屬性時(shí),可選鏈操作符將會(huì)使表達(dá)式更短、更簡(jiǎn)明。在探索一個(gè)對(duì)象的內(nèi)容時(shí),如果不能確定哪些屬性必定存在,可選鏈操作符也是很有幫助的。

const adventurer = {name: 'Alice',cat: {name: 'Dinah'} };// 直接操作未知的變量和方法有可能報(bào)錯(cuò) console.log(adventurer.aa.bb) // Uncaught TypeError: Cannot read property 'bb' of undefined console.log(adventurer.aa()) // Uncaught TypeError: adventurer.aa is not a function// 使用可選鏈操作符可避免報(bào)錯(cuò) const dogName = adventurer.dog?.name; console.log(dogName); // undefinedconsole.log(adventurer.someNonExistentMethod?.()); // undefined

語(yǔ)法:

obj?.prop // 對(duì)象 obj?.[expr] // 對(duì)象 arr?.[index] // 數(shù)組 func?.(args) // 函數(shù)

通過(guò)連接的對(duì)象的引用或函數(shù)可能是 undefined 或 null 時(shí),可選鏈操作符提供了一種方法來(lái)簡(jiǎn)化被連接對(duì)象的值訪問(wèn)。

比如,思考一個(gè)存在嵌套結(jié)構(gòu)的對(duì)象 obj。不使用可選鏈的話,查找一個(gè)深度嵌套的子屬性時(shí),需要驗(yàn)證之間的引用,例如:

// 以前的寫(xiě)法 let nestedProp = obj.first && obj.first.second;// 可選鏈操作符寫(xiě)法 let nestedProp = obj.first?.second;

通過(guò)使用 ?.操作符取代.操作符,JavaScript 會(huì)在嘗試訪問(wèn) obj.first.second 之前,先隱式地檢查并確定 obj.first 既不是 null 也不是 undefined。如果obj.first 是null或者 undefined,表達(dá)式將會(huì)短路計(jì)算直接返回 undefined。

等價(jià)于以下表達(dá)式,但實(shí)際上沒(méi)有創(chuàng)建臨時(shí)變量:

let temp = obj.first; let nestedProp = ((temp === null || temp === undefined) ? undefined : temp.second);

可選鏈與函數(shù)使用

let result = someInterface.customMethod?.();

函數(shù)使用可選鏈操作符場(chǎng)景:

function doSomething(onContent, onError) {try {// ... do something with the data}catch (err) {onError?.(err.message); // 如果onError是undefined也不會(huì)有異常} }

可選鏈與表達(dá)式

當(dāng)使用方括號(hào)與屬性名的形式來(lái)訪問(wèn)屬性時(shí),你也可以使用可選鏈操作符:

let nestedProp = obj?.['prop' + 'Name'];

可選鏈能用于賦值:

let object = {}; object?.property = 1; // Uncaught SyntaxError: Invalid left-hand side in assignment

可選鏈訪問(wèn)數(shù)組

let arrayItem = arr?.[42];

空值合并運(yùn)算符(Nullish coalescing Operator)

空值合并操作符(??)是一個(gè)邏輯操作符,當(dāng)左側(cè)的操作數(shù)為 null 或者 undefined時(shí),返回其右側(cè)操作數(shù),否則返回左側(cè)操作數(shù)。

與邏輯或操作符(||)不同,邏輯或操作符會(huì)在左側(cè)操作數(shù)為假值時(shí)返回右側(cè)操作數(shù)。也就是說(shuō),如果使用 || 來(lái)為某些變量設(shè)置默認(rèn)值,可能會(huì)遇到意料之外的行為。比如為假值(例如,’’ 或 0)時(shí)。見(jiàn)下面的例子。

const foo = null ?? 'default string'; console.log(foo); // "default string"const baz = 0 ?? 42; console.log(baz); // 0

使用空值合并操作符

console.log(null ?? "defaultValue1") // "defaultValue1" console.log(undefined ?? "defaultValue2") // "defaultValue2" console.log("" ?? "defaultValue3") // "" console.log(0 ?? "defaultValue4") // 0 console.log(40 ?? "defaultValue5") // 40

為變量賦默認(rèn)值
以前,如果想為一個(gè)變量賦默認(rèn)值,通常的做法是使用邏輯或操作符(||):

let foo;// foo is never assigned any value so it is still undefined let someDummyText = foo || 'Hello!';

然而,由于||是一個(gè)布爾邏輯運(yùn)算符,左側(cè)的操作數(shù)會(huì)被強(qiáng)制轉(zhuǎn)換成布爾值用于求值。任何假值(0,'', NaN, null, undefined)都不會(huì)被返回。這導(dǎo)致如果你使用0,''或NaN作為有效值,就會(huì)出現(xiàn)不可預(yù)料的后果。

let count = 0; let text = "";let qty = count || 42; let message = text || "hi!"; console.log(qty); // 42,而不是 0 console.log(message); // "hi!",而不是 ""

空值合并操作符可以避免這種陷阱,其只在第一個(gè)操作數(shù)為null或 undefined時(shí)(而不是其它假值)返回第二個(gè)操作數(shù):

let myText = '';let notFalsyText = myText || 'Hello world'; console.log(notFalsyText); // Hello worldlet preservingFalsy = myText ?? 'Hi neighborhood'; console.log(preservingFalsy); // ''

短路
與 OR 和 AND 邏輯操作符相似,當(dāng)左表達(dá)式不為 null或 undefined 時(shí),不會(huì)對(duì)右表達(dá)式進(jìn)行求值。

function A() { console.log('函數(shù) A 被調(diào)用了'); return undefined; } function B() { console.log('函數(shù) B 被調(diào)用了'); return false; } function C() { console.log('函數(shù) C 被調(diào)用了'); return "foo"; }console.log( A() ?? C() ); // 依次打印 "函數(shù) A 被調(diào)用了"、"函數(shù) C 被調(diào)用了"、"foo" // A() 返回了 undefined,所以操作符兩邊的表達(dá)式都被執(zhí)行了console.log( B() ?? C() ); // 依次打印 "函數(shù) B 被調(diào)用了"、"false" // B() 返回了 false(既不是 null 也不是 undefined) // 所以右側(cè)表達(dá)式?jīng)]有被執(zhí)行

不能直接與AND或OR操作符共用

null || undefined ?? "foo"; // 拋出 SyntaxError true || undefined ?? "foo"; // 拋出 SyntaxError

但是加了括號(hào)來(lái)表明運(yùn)算優(yōu)先級(jí),沒(méi)有問(wèn)題:

(null || undefined ) ?? "foo"; // 返回 "foo"

與可選鏈操作符(?.)的關(guān)系

let customer = {name: "Carl",details: { age: 82 } }; let customerCity = customer?.city ?? "暗之城"; console.log(customerCity); // “暗之城”

總結(jié)

以上是生活随笔為你收集整理的【ES11(2020)】可选链操作符和空值合并运算符的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 污网站免费在线观看 | 亚洲福利视频一区二区 | 美国黄色片网站 | 一区二区欧美在线 | 波多av在线 | 日韩av中文| 国产精品三级在线观看无码 | 日韩精品午夜 | 韩国中文字幕在线观看 | 欧美日韩免费做爰视频 | 欧美视频免费在线 | 伊人网久久久 | 香蕉污视频在线观看 | 午夜精品一区二区三区在线 | 欧美我不卡 | 国产高清一区二区三区 | 东京热毛片 | 国精产品一区一区三区有限公司杨 | 337p粉嫩大胆噜噜噜亚瑟影院 | 亚洲色成人www永久网站 | 在线免费观看www | 蜜臀精品一区二区三区 | 欧美成人免费高清视频 | 影音先锋中文字幕在线 | 国产精品美女久久久久av超清 | 久久久久久久国产精品毛片 | 国产99在线 | 亚洲 | 国产一区二区av在线 | 色综合激情 | 亚洲天堂五月 | mm131在线| 女生扒开尿口给男生捅 | 国产日韩一区二区 | 黄瓜视频色 | 毛片99| 欧美污视频| 亚洲色图图片区 | 久久久性视频 | 中文字幕线人 | 欧美激情校园春色 | 麻豆精品国产传媒av | 伊人成人在线 | 色偷偷人人澡人人爽人人模 | 国产伦精品一区二区三区视频1 | 成人免费xxxxx在线观看 | 中国a级大片 | 亚洲毛片网 | 久久99影院 | 老色驴综合网 | 欧美视频在线观看 | 久久色视频 | 四虎影院永久地址 | 日韩精品人妻一区二区中文字幕 | 91在线一区 | 天天干天天操心 | 四虎影视www在线播放 | 亚洲精品911| 日本免费黄色 | 久久久精品999 | 国产鲁鲁视频在线观看免费 | 色呦呦视频 | 亚洲aⅴ在线 | 成人一区二区在线观看 | 日韩av在线电影 | 一本久久精品一区二区 | 麻豆亚洲精品 | 超碰97在线看 | 在线观看黄色大片 | 综合网五月 | 中文字幕在线影院 | xxxwww国产| 亚洲成成品网站 | 亚洲国产日韩av | 久久成人国产 | 97久久人澡人人添人人爽 | 欧美一区二区三区在线 | 超碰人人爱人人 | 色翁荡息又大又硬又粗又爽 | 超碰人人网 | 色婷婷六月天 | av天天网| 少妇av一区二区 | 亚洲黄色大全 | 四虎午夜影院 | 久久久国 | 欧美亚洲韩国 | 中文字幕在线观看的网站 | 黄色网页大全 | 国产波霸爆乳一区二区 | 精品国产xxx| 日韩一区二区三区久久 | 一区成人| 538在线精品| 日本黄区免费视频观看 | 久久.com| 99免费观看视频 | 高h乱l高辣h文短篇h | 成年人爱爱视频 | 蜜桃av一区二区三区 |