掌握 JavaScript 中的 ??=
運(yùn)算符:優(yōu)雅處理 null
和 undefined
值
nullish
合并賦值運(yùn)算符 ??=
是 JavaScript 中相對較新的一個(gè)特性。它在 ECMAScript 2021(ES12)中作為“邏輯賦值運(yùn)算符”提案的一部分被正式引入。
可以將 ??=
看作是變量的智能守護(hù)者。它只在當(dāng)前值為 null
或 undefined
時(shí),才會(huì)將新值賦給變量。
// Old way (pre-2021)
if (user.name === null || user.name === undefined) {
user.name = 'Anonymous';
}
// Or using the nullish coalescing operator (??)
user.name = user.name ?? 'Anonymous';
// New way (ES2021 and later)
user.name ??= 'Anonymous';
當(dāng)您編寫代碼如 user.name ??= 'Anonymous'
時(shí),nullish
合并賦值運(yùn)算符 ??=
首先會(huì)檢查 user.name
是否為 null
或 undefined
。
- 如果
user.name
的值為 null
或 undefined
,那么它會(huì)被賦值為 'Anonymous'
。 - 如果
user.name
已經(jīng)有一個(gè)值,哪怕是空字符串或 0
,user.name
的值將保持不變,不會(huì)進(jìn)行賦值操作。
為何 ??=
優(yōu)于其他替代方案
在 ??=
出現(xiàn)之前,我們有幾種處理默認(rèn)值的方法,但每種方法都有其缺點(diǎn)。比較以下這些方法:
// Using if statement - verbose and repetitive
if (user.name === null || user.name === undefined) {
user.name = 'Anonymous';
}
// Using || operator - catches too much
user.name = user.name || 'Anonymous'; // Replaces '', 0, false too
// Using ternary - gets messy with longer expressions
user.name = user.name === null || user.name === undefined
? 'Anonymous'
: user.name;
// Using ??= - clean and precise
user.name ??= 'Anonymous';
??=
運(yùn)算符為我們提供了前所未有的精確控制。它僅在我們確實(shí)遇到 null
或 undefined
時(shí)才會(huì)觸發(fā)賦值,這使得它非常適合那些0
、''
或 false
被視為有效數(shù)據(jù)的場景:
let score = 0;
score ??= 100; // Keeps 0
let tag = '';
tag ??= 'default'; // Keeps empty string
let active = false;
active ??= true; // Keeps false
這種精確性有助于避免在使用更寬泛的檢查時(shí)可能引發(fā)的錯(cuò)誤。在構(gòu)建用戶界面或處理表單數(shù)據(jù)時(shí),通常需要保留諸如0
、''
或 false
這樣的假值,而不是用默認(rèn)值將它們覆蓋。
原文地址:https://www.trevorlasn.com/blog/javascript-nullish-coalescing-assignment-operator
該文章在 2024/11/28 17:40:20 編輯過