查看: 49|回复: 0

typescript 交叉类型的实现示例

[复制链接]

0

主题

0

回帖

0

积分

积极分子

金币
0
阅读权限
220
精华
0
威望
0
贡献
0
在线时间
0 小时
注册时间
2008-2-27
发表于 2025-12-30 10:29:31 | 显示全部楼层 |阅读模式

一,前言

1,交叉类型是将多个类型合并为一个类型。 这让我们可以把现有的多种类型叠加到一起成为一种类型,它包含了所需的所有类型的特性

二,交叉类型使用

1.我们可以使用type来声明一个新的交叉类型

interface A{
	a:number
}

interface B{
	b:string
}

type C = A & B //C 同时拥有A和B的所有属性

2.接口的交叉类型生成一个新的接口类型,含有两者的所有属性,在使用时,也要满足新的接口的形状

三,注意事项

1.并不是所有类型都适合交叉类型,例如原子类型的交叉是没有意义的,string & number 是没有意义的,没有一种类型既是string也是number

2.对于两个接口类型的交叉类型,当两个接口含有相同的属性时,若这两个属性的类型相同,则合并为这一个类型,若不同,那么整个交叉类型返回never

interface A{
	a:number
}

interface B{
	a:string
}

type C = A & B //C 是never类型

3.注意和联合类型区分开,一个是既是也是,一个是或者

回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部