泛型本质属于类型的一种, 是一种不确定的类型。 通俗的理解, 泛型就是解决类, 接口, 方法的复用性以及对不特定类型和对未来类型支持的一种类型。 因为不确定, 所以泛型是模糊的, 抽象的。 比如, 有这样一个需求, 获得用户传入的值
// 传入类型和返回类型都是string
function getDate(value: string): string {
return value;
}
// 传入类型和返回类型都是number
function getDate1(value: number): number {
return value;
}
上述两个方法只能传number类型的值和string的值, 还得调用不同的方法, 会造成代码的冗余。 泛型出现了, 我们可以这样写
// T就是泛型, 一个函数实现所有类型的返回
function getDate<T>(value: T): T {
return value;
}
let a = getDate<number>(100) // number类型
let b = getDate<string>("hello") // string类型
let c = getDate<Boolean>(true) // booleam类型
... // 其他类型
console.log(a)
console.log(b)
console.log(c)
image
有人说了, 用 any 也可以实现同样的效果, 但是别忘了, 当使用any类型后, 相当于放弃了typescript类型的校验, 这并不符合typescript的规范。