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

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

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

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

1. 非空判斷

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

解析一下:data ?? ' '

使用空值合并操作符 ??,它會(huì)檢查 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

說(shuō)到這,那就簡(jiǎn)單了解一下 空值合并操作符 --- ?? 吧。

2. 基本介紹

空值合并操作符是 JS 中一個(gè)非常實(shí)用的邏輯運(yùn)算符,用于處理 null 和 undefined 值。它允許我們提供一個(gè)默認(rèn)值,當(dāng)一個(gè)表達(dá)式的結(jié)果是 null 或 undefined 時(shí),就會(huì)返回這個(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)值,它不會(huì)對(duì) null 和 undefined 做特殊處理,而是對(duì)其他的“假值”(如: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è)“真值”

- ?? :只對(duì) null 和 undefined 處理

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

4. 注意事項(xiàng)

4.1 優(yōu)先級(jí)

在使用 ?? 時(shí),必須注意運(yùn)算符的優(yōu)先級(jí),特別是在與其他邏輯運(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í)際開(kāi)發(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,也會(huì)被替換為 5,不是我們想要的結(jié)果,所有這種情況下,?? 會(huì)更加合適。

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

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

相關(guān)文章

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

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

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

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

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

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

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

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

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

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

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

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

    JavaScript有許多小竅門來(lái)使編程更加容易。 其中之一就是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中的事件對(duì)象

    一起深入理解js中的事件對(duì)象

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

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

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

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

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

最新評(píng)論