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

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

 更新時(shí)間:2025年01月16日 12:08:40   作者:i_am_a_div_日積月累_  
文章介紹了可選鏈操作符(?.)和空值合并操作符(??)的使用方法,并對(duì)比了它們與邏輯非運(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)讲檎也坏较乱粋€(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ū)別
??:僅僅在 nullundefined 時(shí)返回 defaultValue
||:不僅會(huì)在 nullundefined 時(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í)檢查 undefinednull

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

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

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

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

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

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中xml操作實(shí)現(xiàn)代碼

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

    好久沒寫了。感覺今時(shí)今日,HTML5 還依然只是一種玩票的東東。但愿 w3c 的標(biāo)準(zhǔn)可以早一點(diǎn)出臺(tái),不要讓各種瀏覽器的兼容問題和支持程度搞死
    2011-11-11
  • 淺談如何使用webpack構(gòu)建多頁面應(yīng)用

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

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

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

    本文梳理lodash中那些高頻使用的超究極無敵好用方法,熟練使用下面的十個(gè)方法能夠讓你的代碼原地起飛,為你的開發(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)滾動(dòng)條滾動(dòng)到頁面底部自動(dòng)加載增加內(nèi)容的js代碼

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

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