2.3 TypeScript 非空斷言操作符(后綴 !)詳解

在 TypeScript 中,當你開啟了嚴格的空值檢查(strictNullChecks)后,變量如果可能是 nullundefined,就必須在使用前進行顯式的判斷。為了在某些場景下簡化代碼,TypeScript 提供了非空斷言操作符! 后綴符號),用來告訴編譯器:“我確定這個值不是 null 或 undefined。”

這在你非常確信某個值在使用時一定有效、不會為空時特別有用。

一、語法說明

const nonNullValue: Type = value!;
  • nonNullValue:你希望保存非空值的變量。
  • Type:你期望該變量的類型。
  • value:你正在斷言不會為 nullundefined 的原始值。
  • !:告訴 TypeScript 編譯器,value 一定不是空值。

二、使用場景示例

示例 1:參數可能為 null 的函數

我們定義了一個接收 name 參數的函數 greetUser,該參數的類型為 string | null。為了確保后續使用時不會因 null 而報錯,我們使用非空斷言操作符 !,告訴編譯器這個值一定不為空。

function greetUser(name: string | null) {// 使用非空斷言操作符,確保 name 非空const formattedName: string = name!;console.log(`Hello, ${formattedName || 'Felixlu'}!`);
}greetUser("JackWang"); // 輸出: Hello, JackWang!
greetUser(null);     // 輸出: Hello, Felixlu!

? 注意:雖然使用了 !,但 null 依然傳入了,此時 formattedNamenull,所以回退到 'Felixlu'。這說明 ! 只影響編譯階段的類型檢查,不會改變運行時行為。

示例 2:訪問可選屬性時使用非空斷言

下面我們定義了一個 User 類型,它的 email 屬性是可選的(email?: string),也就是說它可能為 undefined。在訪問 email 時,TypeScript 會提示可能為空,但如果我們確信它一定存在,可以使用 ! 進行斷言:

type User = {name: string;email?: string;
};const user: User = {name: "Felixlu",// 未提供 email
};// name 是必填屬性,無需斷言
const userName: string = user.name;// 使用非空斷言訪問 email
const userEmail: string = user.email!;console.log(`User Name: ${userName}`);
console.log(`User Email: ${userEmail}`);

輸出:

User Name: Felixlu
User Email: undefined

?? 注意user.email! 斷言只告訴編譯器不要報錯,但不會阻止你訪問一個實際為 undefined 的值。因此運行時仍然會輸出 undefined,你需要自己保證其存在性。

三、使用非空斷言的最佳實踐

雖然 ! 操作符非常方便,但也有一定風險。以下是一些建議:

? 推薦使用的場景

? 應避免的場景

你 100% 確信某個值已經初始化或賦值完畢

值的存在依賴異步邏輯或外部條件

在模板渲染、DOM 操作中確保某元素已掛載

在尚未完成數據加載前使用非空斷言

示例:推薦使用場景

const input = document.querySelector('input#username')!;
// 此處 input 一定存在(你確信頁面結構),所以使用 ! 是合理的
input.value = "Felixlu";

四、總結

TypeScript 的非空斷言操作符 ! 是一種在你確信值不會為 nullundefined 時,跳過編譯期空值檢查的強大工具。它簡化了代碼邏輯,但也帶來了隱藏的運行時風險。

使用時請確保斷言背后的前提條件是可靠的,否則可能導致難以發現的 bug。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/82691.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/82691.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/82691.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

深度學習:損失函數與激活函數全解析

目錄 深度學習中常見的損失函數和激活函數詳解引言一、損失函數詳解1.1 損失函數的作用與分類1.2 回歸任務損失函數1.2.1 均方誤差(MSE)1.2.2 平均絕對誤差(MAE) 1.3 分類任務損失函數1.3.1 交叉熵損失(Cross-Entropy&…

掌握 npm 核心操作:從安裝到管理依賴的完整指南

圖為開發者正在終端操作npm命令,圖片來源:Unsplash 作為 Node.js 生態的基石,npm(Node Package Manager)是每位開發者必須精通的工具。每天有超過 1700 萬個項目通過 npm 共享代碼,其重要性不言而喻。本文…

Elasticsearch的運維

Elasticsearch 運維工作詳解:從基礎保障到性能優化 Elasticsearch(簡稱 ES)作為分布式搜索和分析引擎,其運維工作需要兼顧集群穩定性、性能效率及數據安全。以下從核心運維模塊展開說明,結合實踐場景提供可落地的方案…

國產三維CAD皇冠CAD(CrownCAD)建模教程:汽車電池

在線解讀『汽車電池』的三維建模流程,講解3D草圖、保存實體、拉伸凸臺/基體、設置外觀等操作技巧,一起和皇冠CAD(CrownCAD)學習制作步驟吧! 汽車電池(通常指鉛酸蓄電池或鋰離子電池)是車輛電氣系…

深入理解 JDK、JRE 和 JVM 的區別

在 Java 中,JDK、JRE 和 JVM 是非常重要的概念,它們各自扮演著不同的角色,卻又緊密相連。今天,就讓我們來詳細探討一下它們之間的區別。 一、JVM JVM 即 Java 虛擬機,它是整個 Java 技術體系的核心。JVM 提供了 Java…

云電腦顯卡性能終極對決:ToDesk云電腦/順網云/海馬云,誰才是4K游戲之王?

一、引言 1.1 云電腦的算力革命 云電腦與傳統PC的算力供給差異 傳統PC的算力構建依賴用戶一次性配置本地硬件,特別是CPU與顯卡(GPU)。而在高性能計算和游戲圖形渲染等任務中,GPU的能力往往成為決定體驗上限的核心因素。隨著游戲分…

撤銷Conda初始化

在安裝miniconda3的過程中,最后系統會出現這一行提示用戶可以選擇自動初始化,這樣的話,系統每次啟動就會自動啟動基礎(base)環境。 但是我們也可以通過 conda init --reverse $shell 來撤銷 Conda 的初始化設置。這將恢…

Flask-SQLAlchemy數據庫查詢:query

1、為什么可以用 模型類.query 來查詢數據庫? 在 Flask 中使用 SQLAlchemy ORM 時,所有繼承自 db.Model 的模型類都會自動獲得一個 query 屬性。 其本質是 db.session.query(模型類) 的快捷方式,無需顯式操作 db.session。 代碼示例&#…

【免費】【無需登錄/關注】度分秒轉換在線工具

UVE Toolbox 功能概述 這是一個用于地理坐標轉換的在線工具,支持兩種轉換模式: 十進制度 → 度分秒 度分秒 → 十進制度 使用方法 十進制度轉度分秒 在"經度"輸入框中輸入十進制度格式的經度值(例如:121.46694&am…

怎么判斷一個Android APP使用了React Native 這個跨端框架

要判斷一個 Android 應用是否使用了 React Native 框架,可以通過以下方法逐步驗證: 一、安裝包結構分析 1. 解壓 APK 將 .apk 文件重命名為 .zip 并解壓,檢查以下特征文件: ? assets/index.android.bundle: React Na…

Pluto實驗報告——基于2ASK的簡易的通信系統

一、實驗目的 1. 熟悉并掌握PLUTO SDR 主動學習模塊的使用; 2.通過matlab 編碼與adalm pluto 相配合達成一個簡易的通信系統,并能 夠傳輸一些較為簡單的信息。 二、實驗原理 2ASK 調制原理: 振幅鍵控是指利用載波的振幅變化來傳遞數字基帶信…

Ubuntu 24-部署FTP和自定義用戶

目錄 一、 安裝 vsftpd 二、創建 FTP 數據目錄 三、創建 FTP 用戶 四、配置 vsftpd 五、重啟 vsftpd 服務 六、增加新用戶腳本 一、 安裝 vsftpd sudo apt update sudo apt install vsftpd -y 二、創建 FTP 數據目錄 sudo mkdir -p /data/ftp sudo chown nobody:nogrou…

MySQL問題:什么是MySQL的中的最左匹配原則?

是指在復合索引中,查詢條件需要按照索引列的順序從最左側列開始依次匹配。只有查詢條件中的列按照索引的最左邊列開始進行匹配,索引才能被有效使用,但有時雖然不是正常順序,由于MySQL中存在優化器,會自動調整順序&…

2025軟考軟件設計師題目

選擇題(綜合題) 確定得分的 1、Linux外設目錄是什么 /dev。存儲磁盤的目錄 2、Linux外設sdc類型設備屬于什么 scsi hard disk。根據第一個字母s盲猜的 3、計算機中讓程序計數器PC不能指向當前運行程序的技術是 流水線。根據流水線的原理 4、Python程…

Deep Evidential Regression

摘要 翻譯: 確定性神經網絡(NNs)正日益部署在安全關鍵領域,其中校準良好、魯棒且高效的不確定性度量至關重要。本文提出一種新穎方法,用于訓練非貝葉斯神經網絡以同時估計連續目標值及其關聯證據,從而學習…

每天掌握一個Linux命令 - sqlite3

Linux 命令工具 sqlite3 使用指南 一、工具概述 sqlite3 是 SQLite 數據庫的命令行工具,用于在 Linux 系統中直接操作 SQLite 數據庫(輕量級、無服務器、嵌入式關系型數據庫)。 核心特點: 無需安裝數據庫服務,直接通…

leetcode:2160. 拆分數位后四位數字的最小和(python3解法,數學相關算法題)

難度:簡單 給你一個四位 正 整數 num 。請你使用 num 中的 數位 ,將 num 拆成兩個新的整數 new1 和 new2 。new1 和 new2 中可以有 前導 0 ,且 num 中 所有 數位都必須使用。 比方說,給你 num 2932 ,你擁有的數位包括…

Python打卡第38天

浙大疏錦行 作業: 了解下cifar數據集,嘗試獲取其中一張圖片 import torch import torch.nn as nn import torch.optim as optim from torch.utils.data import DataLoader , Dataset # DataLoader 是 PyTorch 中用于加載數據的工具 from torchvision im…

AI 數據采集實戰指南:基于 Bright Data 快速獲取招標訊息

AI 數據采集實戰指南:基于Bright Data快速獲取招標訊息 在招標行業中,快速、準確地獲取招標公告、項目詳情、投標截止日期和其他關鍵招標信息,是投標企業提高競標成功率的核心競爭力。然而,招標信息往往分散在不同的平臺和網頁&a…

TCP 三次握手,第一次握手報文丟失會發生什么?

文章目錄 RTO(Retransmission Timeout)注意 客戶端想與服務端建立 TCP 連接時,先發送 SYN 報文,在這之后,如果客戶端遲遲收不到服務端的 SYNACK 報文,就會觸發「超時重傳」機制,重新發送 SYN 報文,而且重傳…