亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js有趣的非空判斷函數(shù) + ?? 實(shí)現(xiàn)

 更新時(shí)間:2024年09月10日 09:41:57   作者:代碼里的小貓咪  
本文介紹了JS中空值合并操作符??的用法,包括如何使用它來判斷數(shù)據(jù)是否為“合法數(shù)據(jù)”,即非空字符串、非undefined和非null,下面就一起來了解一下,感興趣的可以了解一下

分享一個(gè)好玩的函數(shù),用于統(tǒng)一判斷一個(gè)數(shù)據(jù)是否為“合法數(shù)據(jù)”,即判斷該數(shù)據(jù)既不是空字符串,也不是 undefined 和 null。

1. 非空判斷

const isLegalData = (data) => {
  if (((data ?? '') !== '')) {
    return true;
  }
  return false;
};

解析一下:data ?? ' '

使用空值合并操作符 ??,它會檢查 data 的值:

- 如果 data 是 null 或 undefined,則使用空字符串 ' ' 代替,返回 false;

- 如果 data 是 空字符串,返回 false;

- 如果 data 是其他值,則保持 data 的原始值,返回 true。

console.log(isLegalData(undefined)); // false
console.log(isLegalData(null)); // false
console.log(isLegalData('')); // false
console.log(isLegalData('Hello')); // true
console.log(isLegalData(0)); // true
console.log(isLegalData(false)); // true

說到這,那就簡單了解一下 空值合并操作符 --- ?? 吧。

2. 基本介紹

空值合并操作符是 JS 中一個(gè)非常實(shí)用的邏輯運(yùn)算符,用于處理 null 和 undefined 值。它允許我們提供一個(gè)默認(rèn)值,當(dāng)一個(gè)表達(dá)式的結(jié)果是 null 或 undefined 時(shí),就會返回這個(gè)默認(rèn)值。

const value = someVariable ?? defaultValue;

- someVariable:被檢查的變量或表達(dá)式。

- defaultValue:當(dāng) someVariable 為 null 或 undefined 時(shí),返回的默認(rèn)值。

舉個(gè) ??

const username = null;
const displayName = username ?? 'Monica';
console.log(displayName); // 輸出: Monica

3. ?? 與 || 的區(qū)別

在 JS 中,邏輯或運(yùn)算符 || 也常常用于提供默認(rèn)值,它不會對 null 和 undefined 做特殊處理,而是對其他的“假值”(如:0、'' 、false、NaN、null、undefined)進(jìn)行統(tǒng)一處理,視為 false。

const value1 = 0 || 'default';
console.log(value1); // 輸出: default

const value2 = 0 ?? 'default';
console.log(value2); // 輸出: 0

- || :返回第一個(gè)“真值”

- ?? :只對 null 和 undefined 處理

如果我們只想處理 null 和 undefined,而保留其他“假值”,應(yīng)該使用 ??。

4. 注意事項(xiàng)

4.1 優(yōu)先級

在使用 ?? 時(shí),必須注意運(yùn)算符的優(yōu)先級,特別是在與其他邏輯運(yùn)算符(如 || 和 &&)混合使用時(shí)。

如果期望 || 優(yōu)先執(zhí)行:

const result = (someValue || otherValue) ?? defaultValue;

如果期望 ?? 優(yōu)先執(zhí)行:

const result = someValue || (otherValue ?? defaultValue);

4.2 使用環(huán)境

空值合并操作符是 ECMAScript 2020 (ES11) 中的新特性,因此需要確保在現(xiàn)代瀏覽器或支持 ES2020 的 JavaScript 環(huán)境中使用。

5. 示例

如果在實(shí)際開發(fā)中,某些配置項(xiàng)可以是 0 或者 空字符串,但當(dāng)這些配置項(xiàng)是 null 或 undefined 時(shí),則需要提供一個(gè)默認(rèn)值。

const config = {
  maxRetries: 0,
  timeout: undefined,
  cacheSize: null,
};

// 正確使用空值合并操作符
const retries = config.maxRetries ?? 5; // 輸出: 0(因?yàn)?maxRetries 是有效的值)
const timeout = config.timeout ?? 100; // 輸出: 100(因?yàn)?timeout 是 undefined)
const cache = config.cacheSize ?? 365; // 輸出: 365(因?yàn)?cacheSize 是 null)

在這個(gè)例子中,如果使用 || ,即使 maxRetries 為 0,也會被替換為 5,不是我們想要的結(jié)果,所有這種情況下,?? 會更加合適。

空值合并操作符 ?? 對處理 null 和 undefined 非常有幫助,它與傳統(tǒng)的 || 運(yùn)算符相比,更加精確和安全。

到此這篇關(guān)于js有趣的非空判斷函數(shù) + ?? 實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)js 非空判斷 + ?? 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 完美解決手機(jī)網(wǎng)頁中輸入框被輸入法遮擋的問題

    完美解決手機(jī)網(wǎng)頁中輸入框被輸入法遮擋的問題

    下面小編就為大家分享一篇完美解決手機(jī)網(wǎng)頁中輸入框被輸入法遮擋的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • JS截取字符串實(shí)例詳解

    JS截取字符串實(shí)例詳解

    這篇文章主要介紹了JS截取字符串的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了JavaScript截取字符串的常用函數(shù)與具體使用技巧,并附帶說明了JS截取字符串substr和substring方法的區(qū)別,需要的朋友可以參考下
    2015-11-11
  • JavaScript中的無阻塞加載性能優(yōu)化方案

    JavaScript中的無阻塞加載性能優(yōu)化方案

    這篇文章主要介紹了JavaScript中的無阻塞加載性能優(yōu)化方案,本文講解了Deferred Scripts 延期腳本、Dynamic Script Elements 動(dòng)態(tài)腳本元素、XMLHttpRequest Script Injection XHR腳本注入等內(nèi)容,需要的朋友可以參考下
    2014-10-10
  • Javascript 網(wǎng)頁水印(非圖片水印)實(shí)現(xiàn)代碼

    Javascript 網(wǎng)頁水印(非圖片水印)實(shí)現(xiàn)代碼

    在一些B/S結(jié)構(gòu)的應(yīng)用系統(tǒng)中,有很多頁面是需要有水印的。常見的就是公文系統(tǒng)、合同系統(tǒng)等。
    2010-03-03
  • JavaScript?Map?和?Object?的區(qū)別解析

    JavaScript?Map?和?Object?的區(qū)別解析

    在JavaScript中,Map 和 Object 看起來都是用鍵值對來存儲數(shù)據(jù),那么他們有什么不同呢,這篇文章主要介紹了JavaScript?Map?和?Object?的區(qū)別,需要的朋友可以參考下
    2022-08-08
  • Javascript中Eval函數(shù)的使用說明

    Javascript中Eval函數(shù)的使用說明

    JavaScript有許多小竅門來使編程更加容易。 其中之一就是eval()函數(shù),這個(gè)函數(shù)可以把一個(gè)字符串當(dāng)作一個(gè)JavaScript表達(dá)式一樣去執(zhí)行它。
    2008-10-10
  • JavaScript實(shí)現(xiàn)異步提交表單數(shù)據(jù)

    JavaScript實(shí)現(xiàn)異步提交表單數(shù)據(jù)

    這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)異步提交表單數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-05-05
  • 一起深入理解js中的事件對象

    一起深入理解js中的事件對象

    這篇文章主要給大家介紹了關(guān)于js中事件對象的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • bootstrap下拉分頁樣式 帶跳轉(zhuǎn)頁碼

    bootstrap下拉分頁樣式 帶跳轉(zhuǎn)頁碼

    這篇文章主要為大家詳細(xì)介紹了bootstrap下拉分頁樣式,帶跳轉(zhuǎn)頁碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • Javascript異步編程async實(shí)現(xiàn)過程詳解

    Javascript異步編程async實(shí)現(xiàn)過程詳解

    這篇文章主要介紹了Javascript異步編程async實(shí)現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04

最新評論