function getData(value:string):string{
return value;
}
any放弃了类型检查,不管什么类型都可以
可以支持不特定的数据类型
要求:传入你的参数和返回的参数一致
T表示泛型,具体什么类型是调用这个方法的时候决定的
function getData<T>(value:T):T{
return value;
}
getData<number>(123);
比如有个最小的算法,需要同时支持返回数字和字符串两种类型。通过类的泛型来实现
class MinClass<T>{
public list:T[] = [];
add(num:T){
this.list.pust(num);
}
min():T{
var minNum = this.list[0];
for(var i = 0;i<this.list.length;i++){
if(minNum>this.list[i]){
minNum = this.list[i];
}
}
return minNum;
}
}
var m1 = new MinClas<number>();
var m2 = new MinClas<string>();
m1.add(1);
m1.add(3);
m2.add(a);
m2.add(f);
第一种
interface configFn{
<T>(value1:T,value2:T):T;
}
var setData:configFn = function(value1:T,value2:string):T{
return value1+value2;
}
setData<string>(‘name’,‘张三’);
第二种
interface configFn<T>{
(value1:T,value2:T):T;
}
function getData<T>(value1:T,value2:string):T{
return value1+value2;
}
var myGetData:configFn<string> = getData;
myGetData("20","23");
TypeScript 第六讲 ———— TypeScript 泛型
原文:https://www.cnblogs.com/mqflive81/p/11530829.html