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

JavaScript 雙問號操作符(??)的驚人用法,太強大了

開發(fā)
雙問號操作符(??)是一個邏輯操作符,當左側(cè)操作數(shù)為null或undefined時,返回右側(cè)操作數(shù),否則返回左側(cè)操作數(shù)。

JavaScript作為一門不斷發(fā)展的語言,總是在引入新特性來解決開發(fā)者的痛點。其中,ES2020引入的空值合并操作符(Nullish Coalescing Operator),即雙問號操作符(??),是一個簡單卻極其強大的工具,徹底改變了我們處理默認值和空值的方式。

1. 基本概念:什么是??操作符

雙問號操作符(??)是一個邏輯操作符,當左側(cè)操作數(shù)為null或undefined時,返回右側(cè)操作數(shù),否則返回左側(cè)操作數(shù)。這看似簡單,但與我們常用的邏輯或操作符(||)有著本質(zhì)區(qū)別。

const value1 = null ?? 'default';        // 'default'
const value2 = undefined ?? 'default';    // 'default'
const value3 = false ?? 'default';        // false
const value4 = 0 ?? 'default';            // 0
const value5 = '' ?? 'default';           // ''

2. ??與||的關(guān)鍵區(qū)別

在了解??操作符的強大之前,我們需要理解它與||操作符的區(qū)別:

// 使用||
const count = userCount || 10;  // 當userCount為0時,count將為10

// 使用??
const count = userCount ?? 10;  // 當userCount為0時,count將為0

||操作符會將所有"假值"(如0、''、false、NaN等)都視為需要使用默認值的情況,而??操作符只在值為null或undefined時才使用默認值。

3. 實際應用

(1) 表單處理中的默認值

function processForm(data) {
  // 只有當值真正缺失時才使用默認值
  const username = data.username ?? 'guest';
  const items = data.items ?? [];
  const quantity = data.quantity ?? 1;  // 允許quantity為0
  
  // 處理表單邏輯...
}

(2) 配置對象的深層默認值

const config = {
  server: {
    port: 0,  // 有效值,但為"假值"
    host: ''  // 有效值,但為"假值"
  }
};

const userConfig = {};

// 正確處理深層配置
const port = userConfig?.server?.port ?? config.server.port;  // 0
const host = userConfig?.server?.host ?? config.server.host;  // ''

(3) API響應處理

(4) 鏈式默認值

??操作符可以鏈式使用,創(chuàng)建一個"默認值瀑布":

(5) 與可選鏈操作符(?.)完美配合

當與可選鏈操作符(?.)結(jié)合使用時,處理復雜嵌套對象變得異常優(yōu)雅:

const userName = user?.profile?.preferences?.displayName ?? 'Guest';

這行代碼可以安全地深入訪問一個可能不存在的嵌套屬性,并在任何一層為null或undefined時提供默認值。

(6) 條件性執(zhí)行函數(shù)

// 僅當handler存在時才執(zhí)行,否則使用默認處理函數(shù)
(customHandler ?? defaultHandler)(event);

(7) 數(shù)組元素的默認值處理

4. 高級技巧

(1) 結(jié)合解構(gòu)賦值

const { name, age, title = 'Developer', company = 'Unknown' } = employee ?? {};

這個模式不僅能處理employee為null/undefined的情況,還為解構(gòu)出的個別屬性提供默認值。

(2) 在類中使用

class UserPreferences {
  constructor(settings) {
    this.theme = settings?.theme ?? 'light';
    this.fontSize = settings?.fontSize ?? 16;
    this.notifications = settings?.notifications ?? true;
    
    // 即使settings.volume為0也會被保留
    this.volume = settings?.volume ?? 0.5;
  }
}

5. 性能考慮

??操作符不僅語法簡潔,在某些情況下還能帶來性能優(yōu)勢。由于它只檢查null和undefined,比||操作符的類型轉(zhuǎn)換操作更高效。

雙問號操作符(??)雖然看似簡單,卻解決了JavaScript中一個長期存在的痛點:如何正確處理"空值"與"假值"的區(qū)別。

責任編輯:趙寧寧 來源: JavaScript
相關(guān)推薦

2010-07-19 11:00:24

Perl操作符

2010-07-14 14:18:51

Perl操作符

2010-07-14 14:55:07

Perl操作符

2011-04-08 16:26:14

JavaScript

2009-08-21 09:30:05

is和as操作符

2010-07-14 14:46:57

Perl操作符

2022-09-07 09:01:14

JS操作符運算符

2024-03-26 10:10:45

JavaScript操作符操作表達式

2021-05-20 10:22:34

操作符可選鏈操作符編程技巧

2021-10-31 18:59:55

Python操作符用法

2009-08-19 17:26:28

C# 操作符

2009-07-21 09:31:00

Scala操作符

2010-07-19 11:12:43

Perl 不等于

2021-07-19 09:42:45

Spring Boot@ValueJava

2010-07-13 11:11:39

Perl標量

2009-11-30 16:48:08

PHP操作符

2009-07-14 18:34:22

Jython操作符重載

2011-02-25 09:36:06

java操作符

2010-07-14 14:30:31

Perl操作符

2009-09-15 17:16:58

LINQ查詢操作符
點贊
收藏

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