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

JavaScript空值合并運(yùn)算符??使用場景

 更新時(shí)間:2025年09月05日 08:50:13   作者:掘鐵  
這篇文章主要介紹了JavaScript空值合并運(yùn)算符??的相關(guān)資料,??是一個(gè)js邏輯操作符,當(dāng)左側(cè)的操作數(shù)為null或者undefined時(shí),返回其右側(cè)數(shù),否則返回左側(cè)數(shù),文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下

一、核心概念

  1. 作用
    當(dāng)左側(cè)表達(dá)式為 nullundefined 時(shí),返回右側(cè)的默認(rèn)值;否則返回左側(cè)的值。

  2. 與 || 的區(qū)別

    • || 會對 所有假值(如 0''false、NaN)觸發(fā)默認(rèn)值。
    • ?? 僅對 nullundefined 觸發(fā)默認(rèn)值,保留其他假值的語義。
    console.log(0 || 5);    // 5(0 是假值)
    console.log(0 ?? 5);    // 0(0 不是 null/undefined)
    

二、語法規(guī)則

leftExpr ?? rightExpr
  • 短路特性:若 leftExpr 不是 null/undefined,直接返回左側(cè)值,不計(jì)算右側(cè)。
  • 優(yōu)先級:低于 ||&&,但高于三元運(yùn)算符 ? :。建議用 () 明確優(yōu)先級。

三、使用場景

1. 變量默認(rèn)值

const userInput = null;
const name = userInput ?? "Anonymous"; // "Anonymous"

2. 函數(shù)參數(shù)默認(rèn)值

function greet(message) {
  const text = message ?? "Hello";
  console.log(text);
}
greet(null);    // "Hello"
greet(undefined); // "Hello"
greet("");      // ""(保留空字符串)

3. 對象屬性安全訪問

const config = {
  apiUrl: null,
  timeout: 0
};

const url = config.apiUrl ?? "https://default.api";
const timeout = config.timeout ?? 5000; // 0 被保留

4. 結(jié)合可選鏈?.使用

const user = {
  profile: null
};
const username = user?.profile?.name ?? "Guest"; // "Guest"

四、進(jìn)階用法

1. 多級空值合并

const a = null;
const b = undefined;
const c = "Fallback";
const result = a ?? b ?? c; // "Fallback"

2. 與解構(gòu)賦值結(jié)合

const settings = { theme: null };
const { theme = "light", fontSize = 16 } = settings;
// theme 使用 ?? 邏輯,fontSize 使用 = 默認(rèn)值

3. 動(dòng)態(tài)默認(rèn)值

let defaultPort;
const port = process.env.PORT ?? (defaultPort = 3000);

五、注意事項(xiàng)

  1. 不可直接用于未聲明的變量

    // 錯(cuò)誤示例(需確保變量已聲明)
    const value = undeclaredVar ?? 10; // ReferenceError
    
  2. 與 || 混用時(shí)的優(yōu)先級

    const a = null || undefined ?? "default"; // SyntaxError
    const b = (null || undefined) ?? "default"; // "default"
    
  3. 瀏覽器兼容性

    • 支持 ES2020+ 的環(huán)境(Chrome 80+, Firefox 72+, Node.js 14+)。
    • 舊環(huán)境需通過 Babel 插件 @babel/plugin-proposal-nullish-coalescing-operator 轉(zhuǎn)譯。

六、性能優(yōu)化

  • 避免重復(fù)計(jì)算:若右側(cè)是復(fù)雜表達(dá)式,用函數(shù)封裝避免副作用。
    const value = input ?? computeDefault(); // computeDefault() 僅在需要時(shí)執(zhí)行
    

七、替代方案(舊代碼兼容)

// 使用三元運(yùn)算符模擬 ??
const value = (left !== null && left !== undefined) ? left : right;

總結(jié)

運(yùn)算符觸發(fā)默認(rèn)值的條件適用場景
??nullundefined保留其他假值(如 0''
``

掌握 ?? 能顯著提升代碼可讀性,尤其在處理 API 響應(yīng)、配置項(xiàng)等場景時(shí),能更精準(zhǔn)地控制默認(rèn)值邏輯。

到此這篇關(guān)于JavaScript空值合并運(yùn)算符??使用場景的文章就介紹到這了,更多相關(guān)js空值合并運(yùn)算符??內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • js求數(shù)組最大值的八種具體實(shí)現(xiàn)方法

    js求數(shù)組最大值的八種具體實(shí)現(xiàn)方法

    數(shù)組如何求最大值,想必很多的朋友都不會吧,下面這篇文章主要給大家介紹了關(guān)于使用js求數(shù)組最大值的八種方法具體實(shí)現(xiàn)的相關(guān)資料,文中給出了詳細(xì)的代碼示例,需要的朋友可以參考下
    2023-09-09
  • 小程序獲取手機(jī)驗(yàn)證碼倒計(jì)時(shí)的方法

    小程序獲取手機(jī)驗(yàn)證碼倒計(jì)時(shí)的方法

    這篇文章主要為大家詳細(xì)介紹了小程序獲取手機(jī)驗(yàn)證碼倒計(jì)時(shí)的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下<BR>
    2022-08-08
  • Javascript & DHTML上傳文件控件

    Javascript & DHTML上傳文件控件

    首先來做一個(gè)實(shí)例,批量上傳的UI控件。以后一般做的示例也是以UI控件為主的。都是封裝成Object或者用Function封裝成"Class"類。
    2008-07-07
  • 原生js實(shí)現(xiàn)彈跳小球

    原生js實(shí)現(xiàn)彈跳小球

    這篇文章主要為大家詳細(xì)介紹了原生js實(shí)現(xiàn)彈跳小球,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • JavaScript 作用域鏈解析

    JavaScript 作用域鏈解析

    一直對Js的作用域有點(diǎn)迷糊,今天偶然讀到Javascript權(quán)威指南,立馬被吸引住了,寫的真不錯(cuò)。我看的是第六版本,相當(dāng)?shù)暮?,大?000多頁,Js博大精深,要熟悉精通需要大毅力大功夫。謝謝心得吧
    2014-11-11
  • 淺析2種JavaScript繼承方式

    淺析2種JavaScript繼承方式

    這篇文章主要介紹了2種JavaScript主要繼承方式,一種是通過原型的方式,一種是通過借用call&apply的構(gòu)造函數(shù)方式,感興趣的小伙伴們可以參考一下
    2015-12-12
  • JavaScript canvas實(shí)現(xiàn)加載圖片

    JavaScript canvas實(shí)現(xiàn)加載圖片

    這篇文章主要為大家詳細(xì)介紹了JavaScript canvas實(shí)現(xiàn)加載圖片,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • JavaScript Reduce使用詳解

    JavaScript Reduce使用詳解

    這篇文章主要介紹了JavaScript Reduce使用的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用JavaScript,感興趣的朋友可以了解下
    2021-03-03
  • splitChunks精細(xì)控制代碼分割降低包大小

    splitChunks精細(xì)控制代碼分割降低包大小

    這篇文章主要為大家介紹了如何使用splitChunks精細(xì)控制代碼分割來實(shí)現(xiàn)降低包大小的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • JavaScript動(dòng)態(tài)加載樣式表的方法

    JavaScript動(dòng)態(tài)加載樣式表的方法

    這篇文章主要介紹了JavaScript動(dòng)態(tài)加載樣式表的方法,涉及javascript操作樣式表的技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-03-03

最新評論