TypeScript 泛型
时间: 2024-08-13 07:08:03 浏览: 67
TypeScript中的泛型是一种强大的特性,它允许你在定义函数、接口或类时使用一种类型参数,这样可以创建可重用的代码,适应多种类型。泛型的主要目的是提高代码的灵活性和可扩展性。
1. **函数泛型**[^4]:
```typescript
function identity<T>(arg: T): T {
return arg;
}
let result: string = identity<string>("Hello"); // 使用类型参数T为string
```
在这个例子中,`identity`函数接受一个类型参数`T`,并返回与输入相同类型的值。
2. **接口泛型**[^5]:
```typescript
interface Pair<T> {
first: T;
second: T;
}
let pair: Pair<number> = { first: 1, second: 2 };
```
`Pair`接口使用`T`作为键和值的数据类型。
3. **类泛型**[^6]:
```typescript
class ArraySum<T> {
total: T;
constructor(items: T[]) {
this.total = items.reduce((sum, item) => sum + item, 0);
}
}
let sumInstance = new ArraySum<number>([1, 2, 3]); // 创建一个处理数字的实例
```
`ArraySum`类使用泛型来表示可以进行加法操作的数据类型。
阅读全文