首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

条件类型TypeScript

条件类型是TypeScript中的一种高级类型。它允许根据特定条件选择不同的类型。在类型系统中,条件类型能够基于已知的类型信息进行类型转换和推断。

条件类型通常使用三个操作符来定义:T extends U ? X : Y。其中,T是待检查的类型,U是用于检查的类型,X是在T能够赋值给U的情况下返回的类型,Y是在T不能赋值给U的情况下返回的类型。

条件类型在许多场景中非常有用,比如根据泛型类型参数的不同来选择不同的返回类型,或者根据某个属性是否存在来确定类型。它可以帮助开发者更加精确地定义和推断类型,提高代码的可读性和可维护性。

在 TypeScript 中,条件类型可以应用于各种场景。例如,可以使用条件类型定义一个类型,该类型在输入为数组时返回数组的元素类型,而在输入为对象时返回对象的值类型。

下面是一个示例:

代码语言:txt
复制
type ElementType<T> = T extends Array<infer U> ? U : never;

type Person = {
  name: string;
  age: number;
};

type PersonValues = ElementType<Person>; // 编译错误,PersonValues的类型为never

type Numbers = ElementType<number[]>; // Numbers的类型为number

在上面的例子中,ElementType是一个条件类型,它根据输入类型T的不同选择返回不同的类型。当T为数组类型时,ElementType返回数组元素的类型;当T为对象类型时,ElementType返回never类型。

腾讯云提供了一系列云服务来支持云计算领域的需求。虽然不能提及具体的产品名称,但腾讯云的云服务器、云存储、云数据库等产品都可以在云计算领域发挥重要作用。你可以访问腾讯云官方网站,了解更多关于这些产品的详细信息和使用案例。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

TypeScript条件类型

条件类型(Conditional Types)是TypeScript中一种强大的类型系统特性,它允许我们根据类型关系来推断和选择类型。...条件类型通常与泛型一起使用,使我们可以在类型级别上编写更加灵活和复杂的代码。讲解基础用法基本语法条件类型的基本语法如下:T extends U ?...根据条件的结果,返回不同的字符串类型。分布式条件类型条件类型还可以在联合类型上使用,这称为分布式条件类型。当我们传入一个联合类型的参数时,条件类型会遍历每个成员,并根据条件进行推断。...类型推断与条件类型条件类型的最大特点是,它在类型推断时能够根据条件进行智能推断。type MyType = T extends Array ?...条件类型TypeScript类型系统的一个重要部分,它允许我们在类型级别上进行条件分支和类型选择。通过巧妙地组合泛型、联合类型条件类型,我们可以定义出非常复杂且强大的类型

23740

TypeScript条件类型(十)

TypeScript 2.8版本引入了条件类型(Conditional Types),TS条件类型可以进行类型选择,具体用法可以使用三元运算符实现,JS中的三元运算符用法一样,通过判断得到最终结果,TS...条件类型最终得到的是数据类型。...条件类型条件类型允许根据一个或多个条件类型进行推断,并且还能在在类型级别上进行复杂的逻辑运算和类型操作。一、基本用法当T类型可以赋值给U类型时,则返回X类型,否则返回Y类型。...| {}> // "function" | "object"二、分布式条件类型条件类型中,如果被检查的类型是一个 “裸” 类型参数,即没有被数组、元组或 Promise 等包装过,则该条件类型被称为分布式条件类型..."X" : "Y" = "X" | "Y"三、非分布式条件类型当T被数组、元组、Promise等包裹时,则运算过程中不会分解成多个分支,则该条件类型为非分布式条件类型

22020
  • TypeScript】TS条件类型(十二)

    TypeScript 2.8版本引入了条件类型(Conditional Types),TS条件类型可以进行类型选择,具体用法可以使用三元运算符实现,JS中的三元运算符用法一样,通过判断得到最终结果,TS...条件类型最终得到的是数据类型。...条件类型====条件类型允许根据一个或多个条件类型进行推断,并且还能在在类型级别上进行复杂的逻辑运算和类型操作。一、基本用法当T类型可以赋值给U类型时,则返回X类型,否则返回Y类型。...| {}> // "function" | "object"二、分布式条件类型条件类型中,如果被检查的类型是一个 “裸” 类型参数,即没有被数组、元组或 Promise 等包装过,则该条件类型被称为分布式条件类型..."X" : "Y" = "X" | "Y"三、非分布式条件类型当T被数组、元组、Promise等包裹时,则运算过程中不会分解成多个分支,则该条件类型为非分布式条件类型

    22110

    TypeScript 条件类型精读与实践

    TypeScript 也不例外,使用条件类型可以描述输入类型与输出类型之间的关系。 本文同步首发在个人博客中,欢迎订阅、交流。...即当条件类型作用于泛型类型时,联合类型会被拆分使用。...工具类型 心细的读者可能已经发现了 Demo 类型的声明过程其实就是 TypeScript 官方提供的工具类型中 Exclude 的实现原理,其用于将联合类型...true : false) 在 TypeScript类型定义中,若在箭头函数中使用 extends 也是同理,由于从左向右的阅读习惯,也会导致阅读者对类型代码的执行顺序感到困惑。...Curry, R> : R) 结合类型推导使用条件类型TypeScript 中,一般会结合 extends 来使用类型推导 infer 语法。使用它可以实现自动推导类型的目的。

    72420

    索引类型、映射类型条件类型_TypeScript笔记12

    ,即所谓“拆箱” 三.条件类型 条件类型用来表达非均匀类型映射(non-uniform type mapping),能够根据类型兼容关系(即条件)从两个类型中选出一个: T extends U ?...但条件类型无非两种可能类型,所以let b: string | number = a;一定是合法的(无论x是什么类型) 可分配条件类型 可分配条件类型(distributive conditional...TypeScript 还内置了一些常用的条件类型: // 从 T 中去掉属于 U 的子类型的部分,即之前示例中的 Diff type Exclude = T extends U ?...R : any; (摘自TypeScript/lib/lib.es5.d.ts) 具体示例见Predefined conditional types 四.总结 除类型组合外,另2种产生新类型的方式是类型查询与类型映射...类型查询: 索引类型:取现有类型的一部分产生新类型 类型映射: 映射类型:对现有类型做映射得到新类型 条件类型:允许以类型兼容关系为条件进行简单的三目运算,用来表达非均匀类型映射 参考资料 Advanced

    1.7K10

    TypeScript 官方手册翻译计划【九】:类型操控-条件类型

    项目地址:TypeScript-Doc-Zh,如果对你有帮助,可以点一个 star ~ 本章节官方文档地址:Conditional Types 条件类型 在大多数应用的核心中,我们需要基于输入决定执行哪一个逻辑...条件类型就可以用于描述输入类型和输出类型之间的联系。...在条件类型中进行推断 在上面的例子中,我们使用条件类型去应用约束并提取出类型。由于这种操作很常见,所以条件类型提供了一种更简单的方式来完成。...条件类型提供了 infer 关键字,让我们可以推断出条件中的某个类型,并应用到真分支中。...条件类型作用于泛型上时,如果给定一个联合类型,那么这时候的条件类型是可分配的。

    79920

    TypeScript条件语句

    条件语句用于基于不同的条件来执行不同的动作。 TypeScript 条件语句是通过一条或多条语句的执行结果(True 或 False)来决定执行的代码块。...可以通过下图来简单了解条件语句的执行过程: ---- 条件语句 通常在写代码时,您总是需要为不同的决定来执行不同的动作。您可以在代码中使用条件语句来完成该任务。...在 TypeScript 中,我们可使用以下条件语句: if 语句 - 只有当指定条件为 true 时,使用该语句来执行代码 if...else 语句 - 当条件为 true 时执行代码,当条件为 false...default : /* 可选的 */ statement(s); } switch 语句必须遵循下面的规则: switch 语句中的 expression 是一个常量表达式,必须是一个整型或枚举类型...case 的 constant-expression 必须与 switch 中的变量具有相同的数据类型,且必须是一个常量或字面量。

    89510

    TypeScript类型声明

    当我们使用TypeScript编写代码时,类型声明是非常重要的,它帮助我们定义变量、函数、类等的类型,从而提供更好的代码提示、类型检查和代码可读性。...以下是关于TypeScript类型声明的详细内容:基本类型声明在TypeScript中,我们可以使用以下关键字来声明基本类型:let num: number = 42;let str: string =...(Type Assertion)类型断言允许我们手动指定变量的类型,并告诉TypeScript编译器我们知道更多关于变量的类型信息。...: number; readonly id: number;}以上是关于TypeScript类型声明的一些重要内容。通过合理使用类型声明,我们可以增强代码的可读性、类型安全性和可维护性。...类型声明是TypeScript的核心特性之一,可以帮助我们构建更健壮的代码和应用程序。我正在参与2023腾讯技术创作特训营第三期有奖征文,组队打卡瓜分大奖!

    25420

    TypeScript类型推断

    当我们在TypeScript中声明变量但没有明确指定其类型时,TypeScript会尝试根据变量的值进行类型推断。这样可以帮助我们避免手动指定所有类型,使代码更简洁,同时也提供了更好的类型安全性。...TypeScript 推断 y 为 string 类型let z = true; // TypeScript 推断 z 为 boolean 类型在这个例子中,我们没有显式地给变量x、y和z指定类型TypeScript..."]; // TypeScript 推断 names 为 string[] 类型TypeScript会检查数组中所有元素的类型,并根据元素类型推断出数组的类型。...} 类型TypeScript会根据对象字面量中的键值对进行类型推断。...42 : "hello";在这个例子中,变量value的类型是联合类型number | string。TypeScript根据条件表达式的结果进行类型推断。

    37300

    TypeScript函数类型

    声明式类型函数 通过如下代码我们实现了一个返回值为number类型的方法,同时我们也对返回值和参数进行了约束 function funcType(name:string,age:number):number..."张三",18) 对方法进行添加默认值 function funcType2(name:string="张三",age:number=18):number{ return age; } 表达式类型函数...number):number } var funcType6:funcType5=function(name:string,age:number):number{ return age; } 联合类型重载...通过如下代码我们可以实现一个联合类型函数,当然这可以采用重载的方式 当我们的参数是number类型时我们的返回值是number类型,当我们的参数是string类型时我们的返回值是string类型,这一块具体在我们实际业务中可以根据实际需求进行相应修改

    78720
    领券