js有趣的非空判斷函數(shù) + ?? 實現(xiàn)
分享一個好玩的函數(shù),用于統(tǒng)一判斷一個數(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 中一個非常實用的邏輯運算符,用于處理 null 和 undefined 值。它允許我們提供一個默認值,當(dāng)一個表達式的結(jié)果是 null 或 undefined 時,就會返回這個默認值。
const value = someVariable ?? defaultValue;
- someVariable:被檢查的變量或表達式。
- defaultValue:當(dāng) someVariable 為 null 或 undefined 時,返回的默認值。
舉個 ??
const username = null; const displayName = username ?? 'Monica'; console.log(displayName); // 輸出: Monica
3. ?? 與 || 的區(qū)別
在 JS 中,邏輯或運算符 || 也常常用于提供默認值,它不會對 null 和 undefined 做特殊處理,而是對其他的“假值”(如:0、'' 、false、NaN、null、undefined)進行統(tǒng)一處理,視為 false。
const value1 = 0 || 'default'; console.log(value1); // 輸出: default const value2 = 0 ?? 'default'; console.log(value2); // 輸出: 0
- || :返回第一個“真值”
- ?? :只對 null 和 undefined 處理
如果我們只想處理 null 和 undefined,而保留其他“假值”,應(yīng)該使用 ??。
4. 注意事項
4.1 優(yōu)先級
在使用 ?? 時,必須注意運算符的優(yōu)先級,特別是在與其他邏輯運算符(如 || 和 &&)混合使用時。
如果期望 || 優(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. 示例
如果在實際開發(fā)中,某些配置項可以是 0 或者 空字符串,但當(dāng)這些配置項是 null 或 undefined 時,則需要提供一個默認值。
const config = {
maxRetries: 0,
timeout: undefined,
cacheSize: null,
};
// 正確使用空值合并操作符
const retries = config.maxRetries ?? 5; // 輸出: 0(因為 maxRetries 是有效的值)
const timeout = config.timeout ?? 100; // 輸出: 100(因為 timeout 是 undefined)
const cache = config.cacheSize ?? 365; // 輸出: 365(因為 cacheSize 是 null)在這個例子中,如果使用 || ,即使 maxRetries 為 0,也會被替換為 5,不是我們想要的結(jié)果,所有這種情況下,?? 會更加合適。
空值合并操作符 ?? 對處理 null 和 undefined 非常有幫助,它與傳統(tǒng)的 || 運算符相比,更加精確和安全。
到此這篇關(guān)于js有趣的非空判斷函數(shù) + ?? 實現(xiàn)的文章就介紹到這了,更多相關(guān)js 非空判斷 + ?? 內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Javascript 網(wǎng)頁水印(非圖片水印)實現(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 看起來都是用鍵值對來存儲數(shù)據(jù),那么他們有什么不同呢,這篇文章主要介紹了JavaScript?Map?和?Object?的區(qū)別,需要的朋友可以參考下2022-08-08
JavaScript實現(xiàn)異步提交表單數(shù)據(jù)
這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)異步提交表單數(shù)據(jù),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-05-05
Javascript異步編程async實現(xiàn)過程詳解
這篇文章主要介紹了Javascript異步編程async實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-04-04

