对泛型的一个自我理解
泛型的使用,实际上就像一个占位符一样,
我先预定义一个类型,这个类型具体是啥只有在真正使用的时候才知道。从某种角度来看,泛型很像这个 any 类型啊。
泛型的定义语法
泛型的定义使用 <T> 的方式来定义,
其中 T 就是你与定义的类型,这个字母可以随便用,无所谓,只是一个符号而已。泛型定义的时候可以定义多个,只需要在<>中用 逗号隔开就可以。
例如 : <A,B>
写一个常规的泛型方法看看
需求描述 :写一个函数,两个参数,参数1 是泛型类型的,参数2 是一个数字;返回值是 创建【参数2】个 【参数1】 的数组。代码实现如下:
function getArry<T> (value:T,count:number):T[]{let arr:T[] = []for(let i = 0;i < count;i++){arr.push(value)}return arr
}
console.log(getArry<number>(100,3))
console.log(getArry("aabbcc",3))
运行结果如下 :
[ 100, 100, 100 ]
[ 'aabbcc', 'aabbcc', 'aabbcc' ]
泛型方法的其他写法(了解)
因为函数有 函数声明 和 函数表达式 的定义方式。
上面的案例使用的是 函数声明的方式 使用的泛型,
下面 使用 函数表达式的方式 使用一下泛型,实现的效果与上面的案例是一致的。
const getArry2 = function <T>(value:T,count:number):T[]{let arr:T[] = []for(let i = 0;i < count;i++){arr.push(value)}return arr
}
const getArry3 = <T>(value:T,count:number):T[]=>{let arr:T[] = []for(let i = 0;i < count;i++){arr.push(value)}return arr
}
多个泛型参数的写法
多个符号用逗号隔开即可,如 <T,U,B>
写个例子一看就明白了:
function getArry4<T,U> (value:T,value2:U,count:number):void{let arr:T[] = []for(let i = 0;i < count;i++){arr.push(value)}let arr2:U[] = []for(let i = 0;i < count;i++){arr2.push(value2)}console.log(arr)console.log(arr2)}
getArry4(100,"bcd",2)
运行结果:
[ 100, 100 ]
[ 'bcd', 'bcd' ]