typescript 中的可选链、非空断言操作符和空值合并操作符

在 TypeScript 中,有几个操作符在处理可能为 nullundefined 的值时非常有用,它们分别是可选链操作符(Optional Chaining Operator)、非空断言操作符(Non-null Assertion Operator)和空值合并操作符(Nullish Coalescing Operator)。下面是这些操作符的详细解释和示例:

1. 可选链操作符(Optional Chaining Operator)

可选链操作符 ?. 允许你安全地访问嵌套对象的属性,即使某些属性可能是 nullundefined。如果链中的某个部分是 nullundefined,表达式的结果立即返回 undefined,而不是抛出错误。

示例

typescript 复制代码
interface User {
  name?: string;
  address?: {
    city?: string;
  };
}

const user: User = {
  name: "John",
  address: null
};

const city = user.address?.city; // 结果为 undefined,而不是抛出错误

2. 非空断言操作符(Non-null Assertion Operator)

非空断言操作符 ! 用于告诉 TypeScript 编译器某个值一定不是 nullundefined。这在你确信某个值不为空但 TypeScript 无法推断出来的情况下非常有用。

注意: 滥用非空断言操作符可能会导致运行时错误,因此应谨慎使用。

示例

typescript 复制代码
function getName(user: { name?: string }) {
  return user.name!; // 使用非空断言操作符,告诉 TypeScript user.name 一定不为 null/undefined
}

// 使用示例
const user = { name: "Alice" };
console.log(getName(user)); // 输出 "Alice"

3. 空值合并操作符(Nullish Coalescing Operator)

空值合并操作符 ?? 用于为可能为 nullundefined 的表达式提供一个默认值。与逻辑或操作符 || 不同,?? 只在左侧表达式为 nullundefined 时才返回右侧表达式。

示例

typescript 复制代码
const message = null ?? "Default message"; // 结果为 "Default message"
const value = 0 ?? "Default value";        // 结果为 0,因为 0 不是 null 或 undefined

// 另一个示例
const userInput = "";
const displayedMessage = userInput ?? "No input provided"; // 结果为 "",因为 "" 是空字符串,但不是 null 或 undefined
const fallbackMessage = userInput || "No input provided";  // 结果为 "No input provided",因为 || 会在左侧表达式为 falsy 值时返回右侧表达式

总结

  • 可选链操作符 (?.):安全地访问嵌套对象属性,防止 nullundefined 导致的错误。
  • 非空断言操作符 (!):告诉 TypeScript 某个值一定不为 nullundefined,但应谨慎使用。
  • 空值合并操作符 (??):在左侧表达式为 nullundefined 时提供一个默认值,与逻辑或操作符 || 不同,它只关注 nullundefined

这些操作符可以大大提高代码的健壮性和可读性,尤其是在处理可能为 nullundefined 的值时。

相关推荐
道不尽世间的沧桑1 小时前
第17篇:网络请求与Axios集成
开发语言·前端·javascript
bin91534 小时前
DeepSeek 助力 Vue 开发:打造丝滑的复制到剪贴板(Copy to Clipboard)
前端·javascript·vue.js·ecmascript·deepseek
勤奋的凯尔森同学4 小时前
webmin配置终端显示样式,模仿UbuntuDesktop终端
linux·运维·服务器·ubuntu·webmin
月光水岸New5 小时前
Ubuntu 中建的mysql数据库使用Navicat for MySQL连接不上
数据库·mysql·ubuntu
莫忘初心丶5 小时前
在 Ubuntu 22 上使用 Gunicorn 启动 Flask 应用程序
python·ubuntu·flask·gunicorn
晴空万里藏片云6 小时前
elment Table多级表头固定列后,合计行错位显示问题解决
前端·javascript·vue.js
奶球不是球6 小时前
el-button按钮的loading状态设置
前端·javascript
kidding7236 小时前
前端VUE3的面试题
前端·typescript·compositionapi·fragment·teleport·suspense
无责任此方_修行中7 小时前
每周见闻分享:杂谈AI取代程序员
javascript·资讯
dorabighead9 小时前
JavaScript 高级程序设计 读书笔记(第三章)
开发语言·javascript·ecmascript