typescript基础——泛型

泛型定义

指在定义函数,接口或者类的时候,不预先指定具体的类型,在使用的时候再指定类型的一种特性;

使用

例如:定义一个函数,创建指定长度和值的数组

function createArray(len: number, value: any): Array<any> {}

这样写的缺点是,没有准确的定义返回值的类型
使用泛型修改一下:

function createArray<T>(len: number, value: T): Array<T> {
	let result: T[] = [];
}
createArray<string>(3, '2');

函数名后的T用来指定输入的任意类型, 在使用的时候指定类型;
也可以不指定类型,由类型推论自动推算出来。

多个类型参数

定义泛型的时候可以指定多个类型

function swap<T, U>(arr: [T, U]): [U, T] {
	return [arr[1], arr[0]]
}

泛型约束

在函数内部使用泛型的时候,不确定泛型是什么类型,不能随意操作它的属性或者方法。

interface lengthwise {
   length: number;
}
// 如果不用extends lengthwise,泛型T里不一定包含length属性,编译的时候就会报错。
function logIdentity<T extends lengthwise>(arg: T):T {
   console.log(arg.length);
   return arg;
}

泛型接口

interface CreateArrayFunc {
   <T>(length: number, value: <T>): Array<T>
}
// 可以把泛型参数提到接口名上
// interface CreateArrayFunc<T> {
//    (length: number, value: <T>): Array<T>
// }

// 用第二种使用泛型接口时,必需指定泛型的类型
let createArray: CreateArrayFunc<any>;
createArray = function<T>(length: number, value: <T>): Array<T> {
   
}

泛型类

泛型也可以用在类的类型定义中

class MyClass<T> {
   zeroValue: T;
   constructor(zeroValue: T){
      this.zeroValue = zeroValue
   };
   add: (x: T, y: T) => T;
}
let myClass = new MyClass<number>(12);

泛型参数指定默认值

ts2.3以后,泛型中的类型参数可以指定默认值,使用泛型时,没指定类型也无法推断出类型时,就会采用默认值

function createArray<T = string>(len: number, value: T): Array<T> {
	let result: T[] = [];
}
createArray(3, '2');
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值