JavaScript?中處理?null和?undefined的常見方法
1.可選鏈操作符(?.)
const user = { address: { city: "Beijing" } }; console.log(user.address?.city); // 輸出 "Beijing" console.log(user.unknown?.city); // 輸出 undefined
當(dāng)鏈?zhǔn)讲檎也坏较乱粋€(gè)屬性時(shí)候,就會(huì)返回undefined
2.空值合并操作符(??)
當(dāng)??的左側(cè)值為 null 或 undefined的時(shí)候 就會(huì)取到右側(cè)的 默認(rèn)值
console.log(null ?? "default"); // 輸出 "default" console.log(undefined ?? "default"); // 輸出 "default" console.log("Hello" ?? "default"); // 輸出 "Hello" console.log("" ?? "default"); // 輸出 "" console.log(0 ?? "default"); // 輸出 0 console.log(false ?? "default"); // 輸出 false console.log(false || "default"); // 輸出 default
注意??和||的區(qū)別??
:僅僅在 null
和 undefined
時(shí)返回 defaultValue||
:不僅會(huì)在 null
和 undefined
時(shí)返回 defaultValue,也會(huì)在 false
, 0
, ''
(空字符串) 等其他假值情況下返回默認(rèn)值defaultValue
3.優(yōu)化判斷
一般在判斷if語句時(shí)候,經(jīng)常會(huì)有類似的判斷。 if(a.aa === undefined || a.aa === null || a.aa === ''){ }
是的,可以通過使用更簡(jiǎn)潔和可讀性更高的方式來優(yōu)化這種判斷。以下是幾種常見的優(yōu)化方法:
3.1 使用 == 進(jìn)行寬松比較
使用寬松相等運(yùn)算符 ==
可以同時(shí)檢查 undefined
和 null
:
if (a.aa == null || a.aa === '') { // 處理邏輯 }
3.2 使用邏輯非運(yùn)算符 !
可以利用邏輯非運(yùn)算符 !
來檢查 falsy 值(如 undefined
、null
、''
、0
、NaN
和 false
):
if (!a.aa) { // 處理邏輯 }
不過要注意,這種方式會(huì)將所有 falsy 值都視為 true
,如果你需要排除 0
或 false
,則不適用。
3.3 使用可選鏈和空值合并運(yùn)算符
結(jié)合可選鏈操作符和空值合并運(yùn)算符,可以更加簡(jiǎn)潔:
if (a.aa?.trim() === '') { // 處理邏輯 }
3.4 使用自定義函數(shù)
如果這種檢查在多個(gè)地方使用,可以考慮封裝成一個(gè)函數(shù):
function isEmpty(value) { return value == null || value === ''; } if (isEmpty(a.aa)) { // 處理邏輯 }
總結(jié)
選擇哪種方式取決于具體的需求和上下文。使用 !
運(yùn)算符是最簡(jiǎn)潔的,但需要確保不會(huì)誤判其他 falsy 值。如果需要更嚴(yán)格的檢查,使用 ==
或自定義函數(shù)可能更合適。
到此這篇關(guān)于JavaScript 中處理 null和 undefined情況分析的文章就介紹到這了,更多相關(guān)js處理null和underfined內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript判斷兩個(gè)對(duì)象是否相等的方法總結(jié)
判斷兩個(gè)對(duì)象是否相等是js中的一個(gè)很常見的內(nèi)容,不同的編程語言和環(huán)境可能會(huì)有不同的方式來實(shí)現(xiàn)這一目標(biāo),在 JavaScript 中,判斷兩個(gè)對(duì)象是否相等主要有以下幾種方法,感興趣的小伙伴跟著小編一起來看看吧2024-08-08在JavaScript中使用嚴(yán)格模式(Strict Mode)
這篇文章主要介紹了在JavaScript中使用嚴(yán)格模式(Strict Mode),除了正常運(yùn)行模式,ECMAscript 5添加了第二種運(yùn)行模式:"嚴(yán)格模式"(strict mode)。顧名思義,這種模式使得Javascript在更嚴(yán)格的條件下運(yùn)行。,需要的朋友可以參考下2019-06-06

javascript中xml操作實(shí)現(xiàn)代碼

淺談如何使用webpack構(gòu)建多頁面應(yīng)用

十個(gè)JavaScript?lodash中的高頻使用方法整理

JavaScript 嚴(yán)格模式(use strict)用法實(shí)例分析

當(dāng)滾動(dòng)條滾動(dòng)到頁面底部自動(dòng)加載增加內(nèi)容的js代碼