91网首页-91网页版-91网在线观看-91网站免费观看-91网站永久视频-91网站在线播放

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

探秘 JavaScript 的??= 運算符

admin
2024年11月10日 9:31 本文熱度 1068

掌握 JavaScript 中的 ??= 運算符:優(yōu)雅處理 null 和 undefined 值

nullish 合并賦值運算符 ??= 是 JavaScript 中相對較新的一個特性。它在 ECMAScript 2021(ES12)中作為“邏輯賦值運算符”提案的一部分被正式引入。

可以將 ??= 看作是變量的智能守護(hù)者。它只在當(dāng)前值為 null 或 undefined 時,才會將新值賦給變量。

// 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' 時,nullish 合并賦值運算符 ??= 首先會檢查 user.name 是否為 null 或 undefined

  • 如果 user.name 的值為 null 或 undefined,那么它會被賦值為 'Anonymous'
  • 如果 user.name 已經(jīng)有一個值,哪怕是空字符串或 0user.name 的值將保持不變,不會進(jìn)行賦值操作。

為何 ??= 優(yōu)于其他替代方案

在 ??= 出現(xiàn)之前,我們有幾種處理默認(rè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';

??= 運算符為我們提供了前所未有的精確控制。它僅在我們確實遇到 null 或 undefined 時才會觸發(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

這種精確性有助于避免在使用更寬泛的檢查時可能引發(fā)的錯誤。在構(gòu)建用戶界面或處理表單數(shù)據(jù)時,通常需要保留諸如0''或 false 這樣的假值,而不是用默認(rèn)值將它們覆蓋。


原文地址:https://www.trevorlasn.com/blog/javascript-nullish-coalescing-assignment-operator


該文章在 2024/11/11 10:24:07 編輯過
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點晴ERP是一款針對中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國內(nèi)大量中小企業(yè)的青睞。
點晴PMS碼頭管理系統(tǒng)主要針對港口碼頭集裝箱與散貨日常運作、調(diào)度、堆場、車隊、財務(wù)費用、相關(guān)報表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點,圍繞調(diào)度、堆場作業(yè)而開發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點晴WMS倉儲管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質(zhì)期管理,貨位管理,庫位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務(wù)都免費,不限功能、不限時間、不限用戶的免費OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved

主站蜘蛛池模板: 日本高清视频www | 亚洲无码在线观看a | 国产精品牛牛 | 国产乱人| 91精品福利观看 | 日韩一区二精品服务 | sm免费人成| 日本不卡在线免费 | 绿帽夫妻AV一级 | 国产亚洲玖玖精品 | 中文字幕爱你懂你你 | 国产欧美自拍日韩 | 精品国内成人 | 日韩淫片一区二区 | 午夜成人日韩 | 伦理高清在线观看 | 国产人成亚 | 九九视频免费在线观 | 午夜国产免费 | 国产国语对白露脸 | 日韩美女三级视频 | 欧美日韩看片 | 韩剧高清电影 | 国内自拍第一页 | 欧洲精品色在线观 | 韩国日本在线电影 | 国产日韩欧美第二页 | 国产国产成年在 | 欧美日韩欧美 | 韩国三级激情 | 日韩本免费一 | 国产精品勾引 | 97资源共享视频 | 九一色色 | 日韩欧美另类亚洲 | 国产精品秘A级导航 | 69精品人人人| 九九九在线视频 | 九色自产在线91 | 国产按摩院在线网站 | 91高清福利|