自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

前端小知識:??= 操作符,更簡潔的默認值處理方式

開發(fā) 前端
JavaScript 在 ECMAScript 2021(ES12)中引入的 ??= 操作符提供了一種更簡潔的方案。作為“邏輯賦值操作符”的一部分,它不僅能讓代碼更清晰,還能避免誤替換掉有效數(shù)據(jù)。

在日常開發(fā)中,我們經(jīng)常需要為變量設(shè)置默認值,比如用戶配置、表單初始值等。JavaScript 在 ECMAScript 2021(ES12)中引入的 ??= 操作符提供了一種更簡潔的方案。作為“邏輯賦值操作符”的一部分,它不僅能讓代碼更清晰,還能避免誤替換掉有效數(shù)據(jù)。

什么是 ??= 操作符?

簡單來說,??= 是一個“智能守護者”:僅當變量的值為 null 或 undefined 時才會賦予它一個默認值,而不會影響 0、false、'' 等有效的“假值”。

先看看傳統(tǒng)做法和 ??= 的對比:

// 傳統(tǒng)方法:通過 if 語句檢查和賦值
if (user.name === null || user.name === undefined) {
  user.name = '訪客';
}

// 使用 ??= 簡化后的代碼
user.name ??= '訪客';

在這里,user.name ??= '訪客' 只會在 user.name 為 null 或 undefined 時賦值為 '訪客',否則保留現(xiàn)有值。相比傳統(tǒng)寫法,代碼簡潔了許多,也更清晰。

??= 的典型業(yè)務(wù)應(yīng)用場景

在實際業(yè)務(wù)中,我們經(jīng)常需要處理默認值賦值的場景,在社交平臺中,未設(shè)置用戶名的用戶可能需要顯示“訪客”。利用 ??= 可以避免多余判斷,讓代碼簡潔易讀:

function setDefaultUsername(user) {
  user.username ??= '訪客';
}

let userProfile = { username: null };
setDefaultUsername(userProfile);
console.log(userProfile.username); // 輸出: 訪客

userProfile = { username: '小明' };
setDefaultUsername(userProfile);
console.log(userProfile.username); // 輸出: 小明

這里,user.username ??= '訪客' 會檢查 username 是否為 null 或 undefined。如果是,則賦值為“訪客”;否則保留原有值。非常適合在用戶系統(tǒng)中設(shè)置默認顯示名。

為什么選擇 ??= ?

在 ??= 出現(xiàn)之前,我們有幾種方法可以設(shè)置默認值,但每種方式都有其缺點:

// 使用 if 語句 - 繁瑣且重復(fù)
if (user.name === null || user.name === undefined) {
  user.name = 'Anonymous';
}

// 使用 || 運算符 - 覆蓋太多
user.name = user.name || 'Anonymous';  // 會替換 '', 0, false 等有效值

// 使用三元運算符 - 表達式冗長且難以閱讀
user.name = user.name === null || user.name === undefined
  ? 'Anonymous'
  : user.name;

// 使用 ??= - 簡潔、精確
user.name ??= 'Anonymous';

??= 的優(yōu)勢在于它的精確性。僅當變量真的是“沒有值”時(即 null 或 undefined),它才會賦予默認值,因此適用于保留有效的 0、空字符串或 false 等“假值”數(shù)據(jù):

let score = 0;
score ??= 100;    // 仍然保持 0

let tag = '';
tag ??= 'default'; // 仍然保持空字符串

let active = false;
active ??= true;   // 仍然保持 false

這種精確性能夠有效避免使用更寬泛檢查帶來的潛在問題。在構(gòu)建用戶界面或處理表單數(shù)據(jù)時,我們通常希望保留這些“假值”而不是將它們替換為默認值。

||、&& 與 ?? 的適用場景

在 JavaScript 中,我們還可以使用 || 和 && 處理默認值,但它們的適用場景不同:

  • ||:當變量值是所有“假值”(null、undefined、0、false、'' 等)時都會觸發(fā),可以快速設(shè)置默認值,但可能會覆蓋有效數(shù)據(jù)。
  • &&:用于在兩個條件都成立的情況下進行賦值操作,多用于復(fù)雜條件判斷。
  • ?? 和 ??=:僅在值為 null 或 undefined 時觸發(fā),因此特別適合保留 0、false、空字符串等有效數(shù)據(jù)。

在需要確保變量只在“無值”情況下被覆蓋時,??= 操作符能提供最佳的精確控制。

總結(jié)

??= 操作符讓 JavaScript 的默認值處理更加簡潔和精確。無論是設(shè)置默認用戶名、初始化配置項,還是處理表單初始值,??= 都能幫助我們在確保數(shù)據(jù)完整的前提下,讓代碼更具可讀性和實用性。

責任編輯:趙寧寧 來源: 前端達人
相關(guān)推薦

2022-03-07 14:39:01

前端框架批處理

2009-08-19 17:13:15

C# 操作符基礎(chǔ)知識

2011-05-12 10:48:49

CSS清理浮動

2024-03-05 18:15:28

AsyncAwait前端

2010-07-14 14:55:07

Perl操作符

2009-08-19 17:26:28

C# 操作符

2009-07-21 09:31:00

Scala操作符

2021-10-31 18:59:55

Python操作符用法

2010-02-05 10:30:02

C++操作符重載

2010-07-13 11:11:39

Perl標量

2009-11-30 16:48:08

PHP操作符

2009-07-14 18:34:22

Jython操作符重載

2023-07-10 08:00:13

架構(gòu)Rest返回值

2011-04-08 16:26:14

JavaScript

2010-07-19 11:00:24

Perl操作符

2010-07-14 14:30:31

Perl操作符

2009-09-15 17:16:58

LINQ查詢操作符

2009-09-16 09:09:23

Linq Contai

2010-07-14 14:18:51

Perl操作符

2012-02-06 09:13:23

LINQ
點贊
收藏

51CTO技術(shù)棧公眾號