🎖️typeScrpt中如何断言条件?

简介: `asserts` 语句在 TypeScript 3.7 版本中首度亮相。它是一种特别类型的函数签名,旨在指示 TypeScript 编译器从某特定点开始某个特定条件为真。实际上,这些断言就像 if-then-error 语句的宏一样,赋予我们能力,能够在函数块的开端封装前置条件检查,以此提升代码的可预测性和稳定性。

嗨,大家好!这里是道长王jj~ 🎩🧙‍♂️

asserts 语句在 TypeScript 3.7 版本中首度亮相。它是一种特别类型的函数签名,旨在指示 TypeScript 编译器从某特定点开始某个特定条件为真。实际上,这些断言就像 if-then-error 语句的宏一样,赋予我们能力,能够在函数块的开端封装前置条件检查,以此提升代码的可预测性和稳定性。

初步断言方式

一个检验真实条件的基本断言。请注意函数的返回类型。

function assert(condition: any, msg?: string): asserts condition {
   
  if (!condition) {
   
    throw new Error(msg);
  }
}

这里的 asserts condition 返回类型通知 TypeScript 若函数成功运行,则 condition 必为 true。不然,将引发带指定消息的错误。

下面是如何运用 assert 函数来审视未知参数:

type Point = {
    
  x: number; 
  y: number 
};

function point(x: unknown, y: unknown): Point {
   
  assert(typeof x === 'number', 'x 不是数字');
  assert(typeof y === 'number', 'y 不是数字');

  return {
    x, y };
}

TypeScript 会评估条件 typeof x === 'number' 并推断参数的适当类型。当 assert 调用完毕,TypeScript 已了然 xy 皆为数字。

类型特定断言

asserts 关键字不只能断言条件,它还可以验证变量是否符合特定类型。这透过在 asserts 后面附加类型保护实现。

function assertPoint(val: unknown): asserts val is Point {
   
  if (typeof val === 'object' && 'x' in val && 'y' in val && typeof val.x === 'number' && typeof val.y === 'number') {
   
    return;
  }

  throw new Error('val 不是 Point');
}

只要 assertPoint 函数执行未出错,TypeScript 便会假设 valPoint

function print(point: unknown) {
   
  assertPoint(point);
  console.log(`位置 X=${
     point.x} Y={point.y}`);
}

复杂类型断言

asserts 不止适用于单纯类型或不同条件,它还扩展至能断言较为复杂的类型。一个例子是使用 TypeScript 的 NonNullable<T> 工具类型,以定义一个非空值。

function assertNonNull<T>(val: T): asserts val is NonNullable<T> {
   
  if (val === undefined || val === null) {
   
    throw new Error(`val 是 ${
     val === undefined ? '未定义' : '空值'}`);
  }
}

在此,assertNonNull 函数核查所提供的值既不为 null 也不为 undefinedasserts val is NonNullable<T> 的返回类型传达给 TypeScript:若函数顺利执行,则 val 必定具有定义好的值。

如何将此断言与前一个断言配对以检查多个条件:

function move(point?: unknown) {
   
  assertNonNull(point);
  assertPoint(point);

  console.log(`移动至 ${point.x}, ${point.y}`);
}

函数开头的两个断言帮助 TypeScript 获取有关给定参数特性的信息。在这些条件之后,TypeScript 明了该点已定义,且其为 Point 类型的对象。🚀


🎉 你觉得怎么样?这篇文章可以给你带来帮助吗?当你处于这个阶段时,你发现什么对你帮助最大?如果你有任何疑问或者想进一步讨论相关话题,请随时发表评论分享您的想法,让其他人从中受益。🚀✨

目录
相关文章
|
7月前
|
C++
C++ 条件与 If 语句:掌握逻辑判断与流程控制精髓
C++ 中的条件语句用于根据布尔表达式的真假执行不同代码。`if` 用于当条件为真时执行一段代码,`else` 配合 `if` 在条件不成立时执行另一段代码。`else if` 允许测试额外的条件。`switch` 语句提供多分支选择。还有三元运算符 `(condition) ? expressionTrue : expressionFalse`,它是一种简写的 if...else 形式,常用于一行内作出决定。
99 0
|
5月前
|
存储 前端开发 JavaScript
条件判断的模式问题之如果混淆了断言和卫述如何解决
条件判断的模式问题之如果混淆了断言和卫述如何解决
|
3月前
|
Java
巧用枚举消除条件判断
`shigen`是一位致力于撰写博客文章的作者,记录个人成长历程,分享真知灼见,并捕捉生活中的感动瞬间。在其最新文章中,通过枚举的方式展示了如何优雅地消除if-else判断,提供了一种更为简洁清晰的代码实现方案。利用自定义的`QuestionHandlerEnum`枚举类,实现了不同情况下的逻辑处理,展示了此方法在提升代码可读性和内聚性上的优势。与`shigen`一同探索编程之美,让每一天都有所进步。个人IP:shigen。
15 0
巧用枚举消除条件判断
|
5月前
|
语音技术 数据安全/隐私保护
语音识别,猜猜心里数字讲解,猜数字的组合,判断语句的嵌套,嵌套语句使用很简单,我们写一个外层嵌套的条件,利用缩进,满足条件,才会执行条件2,判断语句综合案例,如何产生变量的随机数字,while循环应用
语音识别,猜猜心里数字讲解,猜数字的组合,判断语句的嵌套,嵌套语句使用很简单,我们写一个外层嵌套的条件,利用缩进,满足条件,才会执行条件2,判断语句综合案例,如何产生变量的随机数字,while循环应用
|
7月前
|
小程序 Java 容器
03|Java基础语法:讲解标识符、关键字、变量、数据类型、运算符、控制语句(条件分支、循环)
03|Java基础语法:讲解标识符、关键字、变量、数据类型、运算符、控制语句(条件分支、循环)
44 0
|
7月前
|
存储 程序员 编译器
【新手解答5】深入探索 C 语言:宏中的文本、标识符和字符串 + 递归运算、条件语句、循环 + `switch-case` 与多项条件和枚举的差别
【新手解答5】深入探索 C 语言:宏中的文本、标识符和字符串 + 递归运算、条件语句、循环 + `switch-case` 与多项条件和枚举的差别
83 0
🎖️typeScrpt中如何使用条件类型和泛型?
我将通过一个可能对日常使用非常有帮助的代码示例更深入地介绍泛型。
77 1
条件测试逻辑判断应用
条件测试逻辑判断应用
55 2
|
Java 测试技术
开发小技巧系列 - 如何避免NPE,巧用Optional重构三元表达式?(三)
NPE是一个老生长谈的问题,无论新手,还是老手,在开发程序的过程中,都不可避免会遇到,而为了处理NPE,往往需要添加很多重复性的检查代码,又长又臭。NPE系列文章,是总结了过往的开发经验,助力更多新手,避免踩坑。
114 0
|
存储 编译器 C语言
循环控制语句的处理及条件分支的处理方法
循环控制语句的处理及条件分支的处理方法
90 0