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

TypeScript交叉类型&联合类型

这里分两种情况,如果同名属性的类型相同则合并后还是原本类型,如果类型不同,则合并后类型为never2.基本数据类型交叉anynumber交叉结果是any类型,anyboolean交叉结果是any类型...,anynever交叉结果是never类型。...二、联合类型(Union types)联合类型交叉类型比较相似,联合类型通过|符号连接多个类型从而生成新的类型。它主要是取多个类型的交集,即多个类型共有的类型才是联合类型最终的类型。...这里我们用in操作符来判断if('x' in testFunc) testFunc.x()扩展:boolean 类型可以看成是 true | false 的联合类型四、类型缩减当字面量类型原始类型进行联合...,如下:enum Class{ A, B }type C = Class.A | Class;//Class类型我们发现:TS会把字面量类型枚举成员类型给缩减掉,只剩下原始类型枚举类型思考一个问题

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

TypeScript联合类型 接口

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

53230

TypeScript联合类型 接口

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

76810

TypeScript联合类型 接口

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

51330

TypeScript 可辨识联合类型

TypeScript 可辨识联合(Discriminated Unions)类型,也称为代数数据类型或标签联合类型。它包含 3 个要点:可辨识、联合类型类型守卫。...这种类型的本质是结合联合类型字面量类型的一种类型保护方法。如果一个类型是多个类型联合类型,且多个类型含有一个公共属性,那么就可以利用这个公共属性,来创建不同的类型保护区块。...二、联合类型 基于前面定义了三个接口,我们可以创建一个 Vehicle 联合类型: type Vehicle = Motorcycle | Car | Truck; 现在我们就可以开始使用 Vehicle...联合类型,对于 Vehicle 类型的变量,它可以表示不同类型的车辆。.../JavaSpring技术栈最新文章。

2.5K10

开心档之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

27610

开心档之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

32420

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

字面量概述字面量就是源代码中一个 固定的值例如数值字面量: 1, 2, 3, ...例如字符串字面量: 'a', 'abc', ...在 TS 中我们可以把字面量作为具体的类型来使用:当使用字面量作为具体类型时..., 该类型的取值就必须是该字面量的值type MyNum = 1;let value1: MyNum = 1;let value2: MyNum = 2;如上的代码在编译器当中 let value2:...MyNum = 2; 是报错的,取值就必须是该字面量的值可辨识联合概述具有共同的 可辨识特征一个类型别名, 包含了具有共同的 可辨识特征 的类型联合关于什么是共同的可辨识特征如下:// 正方形interface...:因为: 它的取值是一个 联合因为: 这个联合的每一个取值都有一个共同的 可辨识特征可辨识联合完整性检查在企业开发中, 如果想对可辨识联合的完整性进行检查, 主要有两种实现方式分别如下方式一给函数添加返回值...大家点赞支持一下哟~ 我正在参与2023腾讯技术创作特训营第二期有奖征文,瓜分万元奖池键盘手表

22120

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

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

1K20

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

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

31930

Typescript:可区分类型联合模式

今天,让我们深入了解 TypeScript 中一个有趣的模式,它将让你大开眼界!这个模式被称为辨识类型联合或辨识联合类型。在深入探讨这个模式之前,让我们先了解问题。...: { message: string };};我创建了一个名为 PokemonState 的类型,其中包含 status、具有特定属性的 pokemon 带有消息的 error。...TypeScript类型安全验证在这里!就像我说的,pokemon error 取决于 state。我们可以在函数中创建一些逻辑来验证每个状态并定义我们是否有这些属性。但这不是最好的解决方案。...现在,让我们介绍我们的模式,称为辨识类型联合。...这种模式根据一个共同的属性将类型分离,使 TypeScript 理解到它是类型安全的。我喜欢这种模式,以及 TypeScript 如何验证使我们的代码更清晰易懂。就是这样!

14010

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

本文将详细介绍 TypeScript 联合类型的定义、使用场景注意事项,并提供一些示例来帮助理解。定义联合类型TypeScript 中,可以使用 | 符号将多个类型组合成一个联合类型。...交叉类型联合类型的结合在 TypeScript 中,还可以使用交叉类型(Intersection Types)联合类型结合使用,从而实现更复杂的类型定义。...联合类型的限制注意事项在使用联合类型时,需要注意以下几点:联合类型只能使用联合类型的公共属性或方法,即类型中共有的属性方法;联合类型不会进行类型缩小,即不能在运行时判断具体的类型;无法对联合类型的变量进行修改...总结本文详细介绍了 TypeScript 联合类型的定义、使用场景注意事项,并提供了一些示例帮助理解。我们学习了如何使用类型断言和类型保护来处理联合类型的变量,以及如何结合交叉类型使用联合类型。...通过灵活使用联合类型,我们可以处理多种类型的变量,提高代码的可读性可维护性。在实际开发中,根据具体的需求选择合适的联合类型,有助于编写出更健壮可靠的 TypeScript 代码。

70841

TypeScript 类型体操:合并映射类型的处理结果为联合类型

索引类型TypeScript 中的常见类型,它是聚合多个元素的类型,对象、类、元组等都是索引类型。...它可以对索引类型的索引值做一些变换,然后产生新的索引类型。...: TypeScript 也内置了很多基于映射类型实现的工具类型,比如 Partial、Required 等。...总结 索引类型TypeScript 中的常见类型,可以通过映射类型的语法来对它做一些修改,生成新的索引类型。...但如果你想对每个索引分别做处理,并且把结果合并为一个联合类型的时候,可以加一层映射类型来分别处理每个索引,再取 keyof Xxx,也就是每个索引类型的处理结果构成的联合类型

1.6K40

联合类型枚举类型

联合联合类型的声明 像结构体⼀样,联合体也是由⼀个或者多个成员构成,这些成员可以不同的类型联合体的特点是所有成员共⽤同⼀块内存空间。所以联合体也叫:共⽤体。...结构体位段的内存分配我已经讲过了,下面带来联合体的内存分配 #include //联合类型的声明 union Un { char c; int i; }; int main() {...(说了以上结论后想必推导出结果很简单,就不说其结果的推导) 而其最大成员大小分别为 514,但是其联合体大小为 8 16....相同成员的结构体联合体对比 我们再对⽐⼀下相同成员的结构体联合体的内存布局情况 struct S { char c; int i; }; struct S s = {0}; union Un...每⼀种商品都有:库存量、价格、商品类型商品类型相关的其他信息。

8410

TypeScript类型断言-类型的声明转换

TS中并不能判断在使用联合类型时具体是那种类型?当我们不知道是什么类型的情况下要使用某个类型特有的属性或者方法,那么就可以用断言来实现,它实际上是对编辑器做了提前告知的行为,但是并不能保证运行中报错。...).length;//0//anyValue是string或者number联合类型,在使用时候将其断言为string类型let anyValue:string | number = 'zhangsan'...,否则不要使用类型断言,这是因为类型断言会让 TypeScript 编译器将变量当做指定的类型,而不管它实际的类型,在程序运行时可能有类型错误,断言需要慎用。...表示,它用来断定某变量一定不是 null undefined。...function func(val:any):any{ return 1}func(1)调用函数时我们改成以下所示,这样方便我们维护代码,约束了传参函数返回值,不能any走天下。

30110
领券