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

TypeScript交叉类型&联合类型

二、联合类型(Union types)联合类型和交叉类型比较相似,联合类型通过|符号连接多个类型从而生成新类型。它主要是取多个类型交集,即多个类型共有的类型才是联合类型最终类型。...联合类型可以是多个类型其中一个,可做选择,比如:string | number,它取值可以是string类型也可以是number类型。...“y”,类型“Y”不存在属性“y”。...这里我们用in操作符来判断if('x' in testFunc) testFunc.x()扩展:boolean 类型可以看成是 true | false 联合类型四、类型缩减当字面量类型和原始类型进行联合...:当接口类型进行联合,接口中同名属性类型不同,该怎么进行缩减呢?

33910

TypeScript】TS联合类型

TypeScript联合类型(Union Types)允许您将多个不同类型组合成一个类型,表示一个值可以是这些类型任何一个。...联合类型使用 | 运算符定义,以下是详细介绍和多个示例:联合类型定义联合类型使用 | 运算符将多个类型组合在一起,如下所示:type Type1 = number;type Type2 = string...;type CombinedType = Type1 | Type2;在上面的示例中,CombinedType 是 Type1 和 Type2 联合类型,表示它可以是一个数字或一个字符串。...("Hello"); // 输出 "Hello"在这个示例中,display 函数接受一个联合类型参数,可以是数字或字符串中任何一个。...,该回调可以处理鼠标事件或键盘事件,因为它是一个联合类型

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

TypeScript联合类型 接口

TypeScript联合类型 联合类型表示取值可以为多种类型一种 如下所示 /** * 联合类型 */ var muchtype:string|number="hello"; muchtype=...1; 这一块我们必须使用string或者number都支持类型,那么下面我们可以进行调用扩展方法toString() /** * 联合类型 * 注意:如果说我们使用字符串length属性那么我们需要注意...,如果是number类型是不支持 * 这一块我们必须使用string或者number都支持类型,那么下面我们可以进行调用扩展方法toString() * */ var muchtype:string...,any必须是任意类型, 因为当我们进行使用不确定属性个数时候会有局限性....当然下面的属性中比如说string number我们也可以使用联合类型,这一块我们后续可以根据实际需求进行变动即可 //属性个数不确定时候 interface IStudent{ name:

52330

TypeScript联合类型 接口

TypeScript联合类型 联合类型表示取值可以为多种类型一种 如下所示 /** * 联合类型 */ var muchtype:string|number="hello"; muchtype=...1; 这一块我们必须使用string或者number都支持类型,那么下面我们可以进行调用扩展方法toString() /** * 联合类型 * 注意:如果说我们使用字符串length属性那么我们需要注意...,如果是number类型是不支持 * 这一块我们必须使用string或者number都支持类型,那么下面我们可以进行调用扩展方法toString() * */ var muchtype:string...,any必须是任意类型, 因为当我们进行使用不确定属性个数时候会有局限性....当然下面的属性中比如说string number我们也可以使用联合类型,这一块我们后续可以根据实际需求进行变动即可 //属性个数不确定时候 interface IStudent{ name:

50630

TypeScript联合类型 接口

TypeScript联合类型 联合类型表示取值可以为多种类型一种 如下所示 /** * 联合类型 */ var muchtype:string|number="hello"; muchtype=...1; 这一块我们必须使用string或者number都支持类型,那么下面我们可以进行调用扩展方法toString() /** * 联合类型 * 注意:如果说我们使用字符串length属性那么我们需要注意...,如果是number类型是不支持 * 这一块我们必须使用string或者number都支持类型,那么下面我们可以进行调用扩展方法toString() * */ var muchtype:string...,any必须是任意类型, 因为当我们进行使用不确定属性个数时候会有局限性....当然下面的属性中比如说string number我们也可以使用联合类型,这一块我们后续可以根据实际需求进行变动即可 //属性个数不确定时候 interface IStudent{ name:

75710

关于 TypeScript联合类型

TypeScript 中,| 符号被用于定义联合类型(Union Types)。联合类型是一种高级类型定义方式,它允许你定义一个类型为多种类型一种。...在 JavaScript 中,我们无法明确指定这个参数类型,但在 TypeScript 中,我们可以使用联合类型来做这个事情: function logInput(input: string | number...联合类型特别有用,因为 TypeScript 会根据联合类型所有可能类型来检查我们代码。...联合类型也可以与其他 TypeScript 特性一起使用,例如类型别名和接口。...总的来说,TypeScript | 符号提供了一种强大方式来处理可能有多种类型值。通过使用联合类型,我们可以编写更灵活代码,同时还能保持强大类型安全性。

22120

TypeScript 可辨识联合类型

TypeScript 可辨识联合(Discriminated Unions)类型,也称为代数数据类型或标签联合类型。它包含 3 个要点:可辨识、联合类型类型守卫。...这种类型本质是结合联合类型和字面量类型一种类型保护方法。如果一个类型是多个类型联合类型,且多个类型含有一个公共属性,那么就可以利用这个公共属性,来创建不同类型保护区块。...联合类型,对于 Vehicle 类型变量,它可以表示不同类型车辆。...四、穷举检查 假设我们想要往前面已经定义 Vehicle 联合类型,添加新类型,那么会出现什么问题呢?下面我们来实际验证一下。...此外我们还引入了 never 类型避免出现新增了联合类型没有对应实现,目的就是写出类型绝对安全代码。

2.5K10

TypeScript-枚举成员类型联合类型

TypeScript-枚举成员类型联合类型枚举成员类型可以把 枚举成员 当做 类型 来使用正确示例:enum Gender { Male, Female}interface TestInterface..., 所以会报错注意点由于数字枚举本质就是数值, 所以写一个数值也不会报错如下:enum Gender { Male, Female}interface TestInterface {...age: Gender.Male}class Person implements TestInterface { age: 0}如果是字符串枚举, 那么只能是枚举成员值, 不能是其它值正确示例...interface TestInterface { age: Gender.Male}class Person implements TestInterface { age: Gender.Female}联合枚举类型联合类型联合类型就是将多种数据类型通过...联合类型 来使用enum Gender { Male, Female}interface TestInterface { age: Gender}class Person implements

21420

开心档之TypeScript 联合类型

TypeScript 联合类型 联合类型(Union Types)可以通过管道(|)将变量设置多种类型,赋值时可以根据设置类型来赋值。 注意:只能赋值指定类型,如果赋值其它类型就会报错。...创建联合类型语法格式如下: Type1|Type2|Type3 ​​实例​​ 声明一个联合类型: ​​TypeScript​​ var val:string|number val = 12 console.log...console.log("数字为 " + val); val = "Runoob"; console.log("字符串为 " + val); 输出结果为: 数字为 12 字符串为 Runoob 如果赋值其它类型就会报错...: var val:string|number val = true 也可以将联合类型作为函数参数使用: ​​TypeScript​​ function disp(name:string|string...Runoob Google Taobao Facebook ---- ​​联合类型数组​​ 我们也可以将数组声明为联合类型: ​​TypeScript​​ var arr:number[]|string

27110

开心档之TypeScript 联合类型

TypeScript 联合类型 联合类型(Union Types)可以通过管道(|)将变量设置多种类型,赋值时可以根据设置类型来赋值。 注意:只能赋值指定类型,如果赋值其它类型就会报错。...创建联合类型语法格式如下: Type1|Type2|Type3 实例 声明一个联合类型TypeScript var val:string|number val = 12 console.log...console.log("数字为 " + val); val = "Runoob"; console.log("字符串为 " + val); 输出结果为: 数字为 12 字符串为 Runoob 如果赋值其它类型就会报错...: var val:string|number val = true 也可以将联合类型作为函数参数使用: TypeScript function disp(name:string|string[])...Runoob Google Taobao Facebook ---- 联合类型数组 我们也可以将数组声明为联合类型TypeScript var arr:number[]|string[]; var

31620

系统学习 TypeScript(五)——联合类型

[TypeScript] 前言 在初步学习了 TypeScript 变量声明后,对它静态类型检查功能简直是爱不释手,但同时也发现一个问题:在正常开发中,一个变量类型有时可能不仅仅只限于 number...到底该怎样限制 res 类型,让它同时满足 number 和 string 类型检查呢?这就涉及到我们今天要学 TypeScript 另一种类型声明——联合类型。...“number”不存在属性“length”。...在给 res 赋值为 12 后,TypeScript 推断 res 类型为 number,number 类型不存在 .length 属性,所以报错。...总结 以上就是 TypeScript 联合类型相关知识,总结起来就是: 联合类型包含了变量可能所有类型; 对联合类型变量赋值为联合类型之外值,会产生报错; 在不能确定联合类型变量最终类型之前,只能访问联合类型所共有的属性和方法

1K20

Typescript:可区分类型联合模式

今天,让我们深入了解 TypeScript 中一个有趣模式,它将让你大开眼界!这个模式被称为辨识类型联合或辨识联合类型。在深入探讨这个模式之前,让我们先了解问题。...TypeScript 类型安全验证在这里!就像我说,pokemon 和 error 取决于 state。我们可以在函数中创建一些逻辑来验证每个状态并定义我们是否有这些属性。但这不是最好解决方案。...现在,让我们介绍我们模式,称为辨识类型联合。...然后创建我们联合类型:type PokemonNewState = | PokemonLoading | PokemonSuccessState | PokemonErrorState;并且更改我们函数参数类型...这种模式根据一个共同属性将类型分离,使 TypeScript 理解到它是类型安全。我喜欢这种模式,以及 TypeScript 如何验证和使我们代码更清晰易懂。就是这样!

13210

TypeScript基础类型:原始类型、对象类型、数组类型、元组类型、枚举类型联合类型

TypeScript 强大类型系统使得开发者能够更轻松地编写可维护、可扩展代码。本文将详细介绍 TypeScript基础类型,包括原始类型、对象类型、数组类型、元组类型、枚举类型联合类型。...也可以手动指定枚举成员数值。联合类型联合类型用于表示一个变量可以是多种类型之一。可以使用 类型1 | 类型2 | ... 语法来声明联合类型。...例如:let value: string | number = "Hello"; // 联合类型value = 123; // 合法联合类型可以提供更大灵活性,使得我们能够处理多种不同类型值。...类型推断和类型断言TypeScript 具有强大类型推断能力,它可以根据上下文自动推断变量类型。例如,如果我们在定义变量时直接赋值,TypeScript 可以推断出变量类型。...总结本文详细介绍了 TypeScript 基础类型,包括原始类型、对象类型、数组类型、元组类型、枚举类型联合类型等方面。

30230

TypeScript-字面量类型TypeScript-可辨识联合、可辨识联合完整性检查

字面量概述字面量就是源代码中一个 固定值例如数值字面量: 1, 2, 3, ...例如字符串字面量: 'a', 'abc', ...在 TS 中我们可以把字面量作为具体类型来使用:当使用字面量作为具体类型时..., 该类型取值就必须是该字面量值type MyNum = 1;let value1: MyNum = 1;let value2: MyNum = 2;如上代码在编译器当中 let value2:...MyNum = 2; 是报错,取值就必须是该字面量值可辨识联合概述具有共同 可辨识特征一个类型别名, 包含了具有共同 可辨识特征 类型 联合关于什么是共同可辨识特征如下:// 正方形interface...return Math.PI * s.radius ** 2; }}如上代码中 Shape 就是一个 可辨识联合:因为: 它取值是一个 联合因为: 这个联合每一个取值都有一个共同...可辨识特征可辨识联合完整性检查在企业开发中, 如果想对可辨识联合完整性进行检查, 主要有两种实现方式分别如下方式一给函数添加返回值 + 开启 strictNullChecks如果实现不完整在编译器当中是会进行报错

16520

TypeScript 联合类型定义、使用场景和注意事项

本文将详细介绍 TypeScript 联合类型定义、使用场景和注意事项,并提供一些示例来帮助理解。定义联合类型TypeScript 中,可以使用 | 符号将多个类型组合成一个联合类型。...使用联合类型类型断言当我们使用联合类型变量时,有时候需要告诉 TypeScript 具体类型,以便进行相应操作。可以使用类型断言(Type Assertion)来实现。...交叉类型联合类型结合在 TypeScript 中,还可以使用交叉类型(Intersection Types)和联合类型结合使用,从而实现更复杂类型定义。...总结本文详细介绍了 TypeScript 联合类型定义、使用场景和注意事项,并提供了一些示例帮助理解。我们学习了如何使用类型断言和类型保护来处理联合类型变量,以及如何结合交叉类型使用联合类型。...通过灵活使用联合类型,我们可以处理多种类型变量,提高代码可读性和可维护性。在实际开发中,根据具体需求选择合适联合类型,有助于编写出更健壮和可靠 TypeScript 代码。

60841

类型即正义:TypeScript 从入门到实践(二):函数、交叉联合类型类型守卫

欢迎阅读 类型即正义:TypeScript 从入门到精通系列: 《类型即正义:TypeScript 从入门到精通系列(序言)》 《类型即正义:TypeScript 从入门到精通系列(一)》 了解了基础...交叉类型联合类型 在前三个大章节中,我们我们讲解了基础 TS 类型,然后接着我们用这些学到基础类型,去组合形成枚举和接口,去注解函数参数和返回值,这都是 TS 类型注解到 JS 元素实践,那么就像...联合类型实际是通过操作符 | ,将多个类型进行联合,组成一个复合类型,当用这个复合类型注解一个变量时候,这个变量可以取这个复合类型任意一个类型,这个有点类似枚举了,就是一个变量可能存在多个类型,...小结 这一小节中我们学习了交叉类型联合类型,它们是 TS 类型系统中类型运算产物,交叉类型是多个类型组成一个类型,最终结果类型是多个类型总和,而联合类型是多个类型组成一个综合体,最终结果类型是多个类型之中某一个类型...字面量类型类型守卫 最后我们来聊一聊类型守卫,类型守卫很多场景都是和联合类型打配合存在。在讲类型守卫时候,我们还需要先聊一聊字面量类型,额!其实这三者是相辅相成

2.7K20
领券