JS使用可選鏈操作符 (?.) 進(jìn)行空值檢查的操作
傳統(tǒng)空值檢
假設(shè)我們有一個嵌套的對象結(jié)構(gòu),想要訪問 user.address.city,但不確定 user、address 或 city 是否存在。傳統(tǒng)的空值檢查方法如下:
let city = null; if (user && user.address && user.address.city) { city = user.address.city; } // let city = user ? (user.address ? user.address.city : null) : null;
這些方法不僅冗長,而且容易出錯.
使用可選鏈操作符 (?.)
可選鏈操作符 (?.) 提供了一種更簡潔的方式來處理這些情況。它允許我們在訪問對象屬性之前檢查對象是否存在,從而避免運(yùn)行時錯誤。
基本用法
let city = user?.address?.city;
如果 user 或 address 為 null 或 undefined,整個表達(dá)式會短路并返回 undefined,而不會拋出錯誤。
示例
假設(shè)我們有以下對象結(jié)構(gòu):
const user = { name: "Alice", address: { street: "123 Main St", city: "Wonderland" } };
使用可選鏈操作符訪問 city:
let city = user?.address?.city; // "Wonderland" let country = user?.address?.country; // undefined
處理數(shù)組
const users = [ { name: "Alice", age: 25 }, { name: "Bob", age: 30 } ]; let secondUserAge = users[1]?.age; // 30 let thirdUserAge = users[2]?.age; // undefined
結(jié)合函數(shù)調(diào)用
const obj = { method: function() { return "Hello"; } }; let result = obj?.method(); // "Hello" let nonExistentResult = obj?.nonExistentMethod(); // undefined
優(yōu)點(diǎn)
- 簡潔性: 減少了代碼量,提高了可讀性。
- 安全性: 避免了因訪問不存在的屬性而導(dǎo)致的運(yùn)行時錯誤。
- 靈活性: 可以方便地處理復(fù)雜的嵌套結(jié)構(gòu)
總結(jié)
可選鏈操作符 (?.) 是 ES2020 引入的一個強(qiáng)大特性,它簡化了空值檢查的過程,提高了代碼的安全性和可讀性。在現(xiàn)代 JavaScript 開發(fā)中,合理使用可選鏈操作符可以顯著減少潛在的錯誤,并使代碼更加簡潔優(yōu)雅。
注意事項(xiàng)
可選鏈操作符只能用于訪問屬性或調(diào)用方法,不能用于賦值。 在某些舊版本的瀏覽器或環(huán)境中可能不支持,需要使用 Babel 等工具進(jìn)行轉(zhuǎn)譯。
到此這篇關(guān)于JS使用可選鏈操作符 (?.) 進(jìn)行空值檢查的操作的文章就介紹到這了,更多相關(guān)JS可選鏈操作符空值檢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Echarts實(shí)現(xiàn)點(diǎn)擊列表聯(lián)動餅圖的示例代碼
本文主要介紹了Echarts實(shí)現(xiàn)點(diǎn)擊列表聯(lián)動餅圖的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05Javascript的異步函數(shù)和Promise對象你了解嗎
這篇文章主要為大家詳細(xì)介紹了Javascript異步函數(shù)和Promise對象,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-03-03前端使用JS內(nèi)置Blob實(shí)現(xiàn)下載各種形式的文件實(shí)例
通過使用JavaScript我們可以很方便地實(shí)現(xiàn)文件的下載功能,這篇文章主要給大家介紹了關(guān)于前端使用JS內(nèi)置Blob實(shí)現(xiàn)下載各種形式文件的相關(guān)資料,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-06-06javascript與css3動畫結(jié)合使用小結(jié)
本文給大家講述的是如何使用javascript結(jié)合CSS動畫來實(shí)現(xiàn)一些占用資源更少,更優(yōu)化的動畫效果,思路十分巧妙,這里推薦給小伙伴們參考下。2015-03-03element?ui?-?el-button?重新渲染后disabled屬性失效問題解決
這篇文章主要介紹了elementui el-button重新渲染后disabled屬性失效問題解決,解決方法也很簡單,給el-button元素添加key值就可以了,需要的朋友可以參考下2023-07-07原生js實(shí)現(xiàn)簡單的Ripple按鈕實(shí)例代碼
本篇文章主要介紹了原生js實(shí)現(xiàn)簡單的Ripple按鈕實(shí)例代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-03-03Javascript load Page,load css,load js實(shí)現(xiàn)代碼
通過js動態(tài)載入頁面和css或js的實(shí)現(xiàn)代碼,需要的朋友可以參考下。國外人寫的,可以參考下。2010-03-03詳解Bootstrap glyphicons字體圖標(biāo)
本章將講解Bootstrap glyphicons字體圖標(biāo),并通過一些實(shí)例了解它的使用,字體圖標(biāo)是在 Web 項(xiàng)目中使用的圖標(biāo)字體。字體圖標(biāo)在下載的Bootstrap的fonts文件夾中2016-01-01