欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript?中處理?null和?undefined的常見方法

 更新時間:2025年01月16日 12:08:40   作者:i_am_a_div_日積月累_  
文章介紹了可選鏈操作符(?.)和空值合并操作符(??)的使用方法,并對比了它們與邏輯非運(yùn)算符(!)的區(qū)別,還討論了使用寬松比較運(yùn)算符(==)和自定義函數(shù)來優(yōu)化判斷的幾種方法,以提高代碼的可讀性和性能,感興趣的朋友跟隨小編一起看看吧

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ū)別
??:僅僅在 nullundefined 時返回 defaultValue
||:不僅會在 nullundefined 時返回 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)算符 == 可以同時檢查 undefinednull

if (a.aa == null || a.aa === '') {
    // 處理邏輯
}

3.2 使用邏輯非運(yùn)算符 !

可以利用邏輯非運(yùn)算符 ! 來檢查 falsy 值(如 undefined、null、''0、NaNfalse):

if (!a.aa) {
    // 處理邏輯
}

不過要注意,這種方式會將所有 falsy 值都視為 true,如果你需要排除 0false,則不適用。

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)文章

  • JS進(jìn)階指南之你真的掌握變量和類型了嗎

    JS進(jìn)階指南之你真的掌握變量和類型了嗎

    變量是存儲信息的容器(JS的變量名是區(qū)分大小寫的),下面這篇文章主要給大家介紹了關(guān)于JS進(jìn)階指南之變量和類型的相關(guān)資料,文章通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-05-05
  • JavaScript判斷兩個對象是否相等的方法總結(jié)

    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)

    這篇文章主要介紹了在JavaScript中使用嚴(yán)格模式(Strict Mode),除了正常運(yùn)行模式,ECMAscript 5添加了第二種運(yùn)行模式:"嚴(yán)格模式"(strict mode)。顧名思義,這種模式使得Javascript在更嚴(yán)格的條件下運(yùn)行。,需要的朋友可以參考下
    2019-06-06
  • 談?wù)凧avaScript令人迷惑的==與+

    談?wù)凧avaScript令人迷惑的==與+

    這篇文章主要介紹了JavaScript中==與+的使用方法,幫助大家更好的理解和學(xué)習(xí)JavaScript,感興趣的朋友可以了解下
    2020-08-08
  • JavaScript中雙等號(==)和三等號(===)有何不同以及何時使用它們詳解

    JavaScript中雙等號(==)和三等號(===)有何不同以及何時使用它們詳解

    這篇文章主要給大家介紹了關(guān)于JavaScript中雙等號(==)和三等號(===)有何不同以及何時使用它們的相關(guān)資料,在JavaScript中"=="和"==="都是比較運(yùn)算符,用于比較兩個值是否相等,需要的朋友可以參考下
    2024-01-01
  • javascript中xml操作實(shí)現(xiàn)代碼

    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)用

    這篇文章主要介紹了淺談如何使用webpack構(gòu)建多頁面應(yīng)用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • 十個JavaScript?lodash中的高頻使用方法整理

    十個JavaScript?lodash中的高頻使用方法整理

    本文梳理lodash中那些高頻使用的超究極無敵好用方法,熟練使用下面的十個方法能夠讓你的代碼原地起飛,為你的開發(fā)之旅極大的減輕心智負(fù)擔(dān),快跟隨小編一起學(xué)習(xí)一下吧
    2024-01-01
  • JavaScript 嚴(yán)格模式(use strict)用法實(shí)例分析

    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代碼

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

    這篇文章主要介紹了如何使用javscript實(shí)現(xiàn)滾動條滾動到頁面底部自動加載增加頁面內(nèi)容,需要的朋友可以參考下
    2014-05-05

最新評論