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

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

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

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

示例

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 无法推断出来的情况下非常有用。

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

示例

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 时才返回右侧表达式。

示例

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 的值时。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/896230.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

屏幕画面卡住不动声音正常怎么办?电脑屏幕卡住不动解决方法

在数字时代,电脑作为我们日常生活与工作中不可或缺的伙伴,偶尔也会遇到一些小状况。其中,“屏幕画面卡住不动,但是声音依然正常”的情况就是一种常见的问题。本文将探讨这一现象的原因,并提供几种可能的解决方案&#…

FSCapture 9.3 | 全能截图与录屏解决方案。

FastStone Capture 是一款轻量级但功能全面的屏幕捕捉工具,能够轻松捕获并标注屏幕上的一切内容,包括窗口、对象、菜单、全屏、矩形/自由区域以及滚动窗口或网页。此外,它还支持录制屏幕活动、声音和网络摄像头,并将这些内容保存为…

[复现]比较6种股市趋势识别方

作者: Filippos Tzimopoulos 翻译整理:进击的小学生 文章名称: I compared 6 methods to identify the trend of the stock market. These are the results! code 与 datas ,请转至获取! 背景说明 通过识别市场方向,交易者可…

webAPI中的排他思想、自定义属性操作、节点操作(配大量案例练习)

一、排他操作 1.排他思想 如果有同一组元素,我们想要某一个元素实现某种样式,需要用到循环的排他思想算法: 1.所有的元素全部清除样式 2.给当前的元素设置样式 注意顺序能不能颠倒,首先清除全部样式,再设置自己当前的…

dyna批处理代码,无需蹲守,自行连续计算

用此代码即可 上面一行是模型位置 下面一行是DYNA模拟器位置 第三个框框是K文件名称 上述三者改成自己的 然后复制修改即可 复制几个就几个进行批处理

深入理解伪元素与伪类元素

在“探秘盒子浮动,破解高度塌陷与文字环绕难题,清除浮动成关键!”中,我们讲到如果父盒由于各种原因未设置高度, 子盒的浮动会导致父盒的高度塌陷。为了解决高度塌陷的问题,我们可以添加伪元素。 一、伪元素…

Android 内存优化——常见内存泄露及优化方案

看到了一篇关于内存泄漏的文章后,就想着分享给大家,最后一起学习,一起进步: 如果一个无用对象(不需要再使用的对象)仍然被其他对象持有引用,造成该对象无法被系统回收,以致该对象在…

【element-tiptap】如何修改选中内容时的背景颜色?

前言:element-tiptap 用鼠标选中内容的时候,背景颜色跟系统设置的主题有关,比如的我的就是卡哇伊的pink,默认是淡蓝色 但是我们观察一下语雀,背景颜色是它规定好的颜色 这篇文章来探索一下,怎么自己规定选…

教学平台的智能化升级:Spring Boot应用

4系统概要设计 4.1概述 本系统采用B/S结构(Browser/Server,浏览器/服务器结构)和基于Web服务两种模式,是一个适用于Internet环境下的模型结构。只要用户能连上Internet,便可以在任何时间、任何地点使用。系统工作原理图如图4-1所示: 图4-1系统工作原理…

除GOF23种设计模式之简单工厂模式

文章目录 1. 简介2. 代码2.1 抽象类:Course.java2.2 产品A:JavaCourse.java2.3 产品B:PythonCourse.java2.4 工厂:CourseFactory.java2.5 测试:Test.java 3. 心得参考链接(无) 1. 简介 简单工厂模式(Simple Factory Patern):又称…

数据结构4——栈

1. 栈的概念及结构 栈的概念: 栈是一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则…

【SuperHotSwap】IDEA零配置热更新插件升级

往期往期插件v1.0.0发布的时候我发表了一篇文章,如下: 支持功能 如今插件迭代了数个版本,现在迎来了v1.9.0版本的重大升级。如下是支持功能。 支持功能是否支持说明MybatisXML热更新√Class热更新√增强功能需安装dcevm补丁。支持动态新增类…

git rebase的常用场景: 交互式变基, 变基和本地分支基于远端分支的变基

文章目录 作用应用场景场景一:交互式变基(合并同一条线上的提交记录) —— git rebase -i HEAD~2场景二:变基(合并分支) —— git rebase [其他分支名称]场景三:本地分支与远端分支的变基 作用 使git的提交记录变得更加简洁 应用场景 场景…

Java爬虫:获取数据的入门详解

在数字化时代,数据已成为最宝贵的资产之一。无论是市场研究、客户洞察还是产品开发,获取大量数据并从中提取有价值的信息变得至关重要。Java,作为一种成熟且功能强大的编程语言,为编写爬虫提供了强大的支持。Java爬虫可以帮助我们…

如何提高外贸网站在谷歌的收录速度?

外贸企业在进行网络推广时,经常遇到网站页面无法被谷歌快速收录的问题。即使你的网站内容优质、设计精美,如果没有被谷歌收录,就等于失去了被客户发现的机会,GSI谷歌快速收录服务就是为了解决这一问题而诞生的。它不仅能够帮助网站…

5G智慧医疗的实践先锋:SR830-E工业路由器的理性应用

在医疗科技日新月异的今天,5G技术无疑为智慧医疗注入了新的活力。然而,技术的进步不应仅停留在理论层面,更应该在实践中发挥其真正价值。今天,我们就来探讨SR830-E工业路由器如何在实际医疗场景中扮演关键角色,推动5G智…

vscode 远程linux服务器 连接git

vscode 远程linux服务器 连接git 1. git 下载2. git 配置1)github 设置2)与github建立连接linux端:创建密钥github端:创建ssh key 3. 使用1)初始化repository2)commit 输入本次提交信息,提交到本…

UE5 圆周运动、贝塞尔曲线运动、贝塞尔曲线点

圆周运动 贝塞尔曲线路径运动 蓝图函数库创建贝塞尔曲线点 // Fill out your copyright notice in the Description page of Project Settings.#pragma once#include "CoreMinimal.h" #include "Kismet/BlueprintFunctionLibrary.h" #include "MyBlu…

从MySQL到OceanBase离线数据迁移的实践

本文作者:玉璁,OceanBase 生态产品技术专家。工作十余年,一直在基础架构与中间件领域从事研发工作。现负责OceanBase离线导数产品工具的研发工作,致力于为 OceanBase 建设一套完善的生态工具体系。 背景介绍 在互联网与云数据库技…

【码农必备】CasaOS香橙派安装Code server+cpolar让远程开发更轻松

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:kwan 的首页,持续学…