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)讲檎也坏较乱粋€屬性時候,就會返回undefined
2.空值合并操作符(??)
當(dāng)??的左側(cè)值為 null 或 undefined的時候 就會取到右側(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 時返回 defaultValue||:不僅會在 null 和 undefined 時返回 defaultValue,也會在 false, 0, '' (空字符串) 等其他假值情況下返回默認(rèn)值defaultValue
3.優(yōu)化判斷
一般在判斷if語句時候,經(jīng)常會有類似的判斷。
if(a.aa === undefined || a.aa === null || a.aa === ''){
}是的,可以通過使用更簡潔和可讀性更高的方式來優(yōu)化這種判斷。以下是幾種常見的優(yōu)化方法:
3.1 使用 == 進(jìn)行寬松比較
使用寬松相等運(yùn)算符 == 可以同時檢查 undefined 和 null:
if (a.aa == null || a.aa === '') {
// 處理邏輯
}3.2 使用邏輯非運(yùn)算符 !
可以利用邏輯非運(yùn)算符 ! 來檢查 falsy 值(如 undefined、null、''、0、NaN 和 false):
if (!a.aa) {
// 處理邏輯
}不過要注意,這種方式會將所有 falsy 值都視為 true,如果你需要排除 0 或 false,則不適用。
3.3 使用可選鏈和空值合并運(yùn)算符
結(jié)合可選鏈操作符和空值合并運(yùn)算符,可以更加簡潔:
if (a.aa?.trim() === '') {
// 處理邏輯
}3.4 使用自定義函數(shù)
如果這種檢查在多個地方使用,可以考慮封裝成一個函數(shù):
function isEmpty(value) {
return value == null || value === '';
}
if (isEmpty(a.aa)) {
// 處理邏輯
}總結(jié)
選擇哪種方式取決于具體的需求和上下文。使用 ! 運(yùn)算符是最簡潔的,但需要確保不會誤判其他 falsy 值。如果需要更嚴(yán)格的檢查,使用 == 或自定義函數(shù)可能更合適。
到此這篇關(guān)于JavaScript 中處理 null和 undefined情況分析的文章就介紹到這了,更多相關(guān)js處理null和underfined內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript判斷兩個對象是否相等的方法總結(jié)
判斷兩個對象是否相等是js中的一個很常見的內(nèi)容,不同的編程語言和環(huán)境可能會有不同的方式來實(shí)現(xiàn)這一目標(biāo),在 JavaScript 中,判斷兩個對象是否相等主要有以下幾種方法,感興趣的小伙伴跟著小編一起來看看吧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中雙等號(==)和三等號(===)有何不同以及何時使用它們詳解
這篇文章主要給大家介紹了關(guān)于JavaScript中雙等號(==)和三等號(===)有何不同以及何時使用它們的相關(guān)資料,在JavaScript中"=="和"==="都是比較運(yùn)算符,用于比較兩個值是否相等,需要的朋友可以參考下2024-01-01
javascript中xml操作實(shí)現(xiàn)代碼
好久沒寫了。感覺今時今日,HTML5 還依然只是一種玩票的東東。但愿 w3c 的標(biāo)準(zhǔn)可以早一點(diǎn)出臺,不要讓各種瀏覽器的兼容問題和支持程度搞死2011-11-11
淺談如何使用webpack構(gòu)建多頁面應(yīng)用
這篇文章主要介紹了淺談如何使用webpack構(gòu)建多頁面應(yīng)用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05
JavaScript 嚴(yán)格模式(use strict)用法實(shí)例分析
這篇文章主要介紹了JavaScript 嚴(yán)格模式(use strict)用法,結(jié)合實(shí)例形式分析了JavaScript 嚴(yán)格模式的基本功能、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-03-03
當(dāng)滾動條滾動到頁面底部自動加載增加內(nèi)容的js代碼
這篇文章主要介紹了如何使用javscript實(shí)現(xiàn)滾動條滾動到頁面底部自動加載增加頁面內(nèi)容,需要的朋友可以參考下2014-05-05

