TypeScript 中的类型收窄

如题所述

第1个回答  2022-06-17

在本文中,我们将学习各种收窄类型的方法。 类型(narrowing)收窄 是将类型从不太精确的类型推导为更精确的类型的过程。

让我们从一个简单的函数开始:

上面的函数可以接受一个数字或一个字符串。假设我们要根据 input 是数字还是字符串来执行不同的操作。在这种情况下,我们将使用 JavaScript 类型保护来检查它是字符串还是数字,如下所示:

在上面的示例中,我们使用 JavaScript 类型保护将输入类型收窄为数字或字符串。类型保护用于检查变量是否属于特定类型,即数字、字符串、对象等。使用类型保护时,Typescript 希望该变量属于该类型。它将根据该信息自动键入并检查其使用情况。

示例中,我们使用 typeof 运算符收窄类型,它检查值是否具有原始类型的类型。

以下是可用的 JavaScript 类型保护的列表:

string

number

bigint

boolean

symbol

undefined

object

function

下面我们来看一下其他的收窄类型方法。

在这种类型收窄中,我们在使用变量之前检查它是否为真。当变量为真时,TypeScript 将自动消除该变量在条件检查中出错的可能性,即 undefined 或 null 等。

举个例子,下面的函数 foo 接受一个参数 x ,其类型为 string 或 undefined (即可选)。

通过检查 x 是否为 true , x 的类型将变为 string ,否则为 undefined 。

很多情况下都会进行真值收窄:表达式( || 、 && 、 ! )、 !! 和 Boolean 等。

如果两个变量相等,那么两个变量的类型必须相同。如果一个变量的类型不精确(即 unknown 、 any 等),并且等于另一个精确类型的变量,那么 TypeScript 将使用该信息收窄第一个变量的类型。

以下面的函数为例,它有两个参数: x 和 y , x 是 string 或 number , y 是 number 。当 x 的值等于 y 的值时, x 的类型被推断为 number ,否则为 string 。

在这种方法中,您创建了一个对象,其中包含一个文本成员,可以用来区分两个不同的联合。

以下例子中,函数计算不同形状的正方形、矩形和圆形。我们将从定义 Rectangle 和 Circle 的类型开始。

从上述类型中,每个对象都将具有 shape 的文字字段,可以是 circle 或 rectangle 。我们可以使用函数中的 shape 字段来计算面积,这将接受 Rectangle 和 Circle 的并集,如下所示:

当 shape 字段是矩形时,您只能访问 Rectangle 类型中可用的属性,即 width 、 height 和 shape 。这同样适用于当 shape 字段是 circle 时,TypesSript 只允许您访问 radius 和 circle ,否则将抛出错误。

in 运算符用于确定对象是否具有包含的属性名。它以 "property" in object 的格式使用,其中 property 是要检查其是否存在于 object 中的属性名。

在上面的例子中,我们使用有区别的并集来区分圆和矩形。我们也可以使用 in 运算符来实现同样的效果,但这次我们将检查一个形状是否包含某些属性,即 Circle 的 radius 、 Rectangle 的 width 和 height ,结果将是相同的。

在这种类型的收窄中,一旦给变量赋值,TypeScript 就会收窄变量的类型。取一个 number 或 string 的联合类型的变量 x ,如果我们给它赋值 number ,类型就变成了一个数,如果我们给它赋值 string ,类型就变成了字符串。

JavaScript 的 instanceof 运算符用于检查某个值是否是某个类的实例。它以 value instanceof value2 的格式使用,并返回一个布尔值。当检查某个值是否为类的实例 instanceof 时,TypeScript 会将该类型分配给变量,从而收窄类型。

以下面的示例为例,其中一个函数接受一个日期,可以是字符串或日期。如果是日期,我们想将其转换为字符串,如果是字符串,我们将按原样返回。我们可以使用 instanceof 检查它是否是 Date 的实例,并将其转换为字符串,如下所示。

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网