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

TypeScript条件类型

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

20140

TypeScript条件类型(十)

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

15920
您找到你想要的搜索结果了吗?
是的
没有找到

TypeScript】TS条件类型(十二)

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

16510

TypeScript 条件类型精读与实践

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

69220

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

: function unproxify(t: Proxify): Person 从参数类型proxyProps: Proxify中取出了Person作为返回值类型...,即所谓“拆箱” 三.条件类型 条件类型用来表达非均匀类型映射(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种产生新类型的方式是类型查询与类型映射

1.6K10

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

项目地址:TypeScript-Doc-Zh,如果对你有帮助,可以点一个 star ~ 本章节官方文档地址:Conditional Types 条件类型 在大多数应用的核心中,我们需要基于输入决定执行哪一个逻辑...条件类型就可以用于描述输入类型和输出类型之间的联系。...在条件类型中进行推断 在上面的例子中,我们使用条件类型去应用约束并提取出类型。由于这种操作很常见,所以条件类型提供了一种更简单的方式来完成。...举个例子,在一些简单的情况下,我们可以从函数类型中提取出返回值类型: type GetReturnType = Type extends (...args: never[]) => infer...条件类型作用于泛型上时,如果给定一个联合类型,那么这时候的条件类型是可分配的。

77920

TypeScript条件语句

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

86710

TypeScript类型声明

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

19720

TypeScript类型推断

当我们在TypeScript中声明变量但没有明确指定其类型时,TypeScript会尝试根据变量的值进行类型推断。这样可以帮助我们避免手动指定所有类型,使代码更简洁,同时也提供了更好的类型安全性。...TypeScript 推断 y 为 string 类型let z = true; // TypeScript 推断 z 为 boolean 类型在这个例子中,我们没有显式地给变量x、y和z指定类型TypeScript...函数返回值类型推断function add(a: number, b: number) { return a + b;}在这个例子中,函数add的返回值没有显式地指定类型,但TypeScript会根据函数体中的...return语句推断出返回值类型为number。...42 : "hello";在这个例子中,变量value的类型是联合类型number | string。TypeScript根据条件表达式的结果进行类型推断。

28600

TypeScript never 类型

它用于表示不返回值的函数的返回类型:例如,永远循环的函数,始终抛出异常信号的函数等。 因为底部类型被用于表示不会正常的返回,一般没有返回值。...例如, never 类型是那些总是会抛出异常或根本就不会有返回值的函数表达式或箭头函数表达式的返回值类型。此外,变量也可能是 never 类型,当它们被永不为真的类型保护所约束时。...let baz: never = 123; // 赋值失败,number类型不能赋值给never类型的变量 // 定义never类型变量,接收返回值类型为never类型的函数返回值 let bar:...never = (() => { throw new Error('TypeScript never'); })(); 另外,对于死循环的函数或执行时总会抛出异常的函数来说,函数对应的返回值类型也是...在这些情况下,我们通常忽略返回值。在 TypeScript 中这些函数的返回类型被推断为 void。 具有 never 返回类型的函数永不返回。它也不返回 undefined。

4K10

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类型,这一块具体在我们实际业务中可以根据实际需求进行相应修改

76820
领券