泛型 泛指所有类型
我们不自己定义类型,让用户用参数的形式告诉函数
需求一个函数传递过来什么类型就返回什么类型
// 不确定用户传递什么类型的参数回来,那么也就不能确定返回值
function getLength(arg: string | number | any[]): string | number | any[] {
return arg
}
getLength('1234')
getLength(123)
getLength([1, 2, 3])
// 类型的参数化 --- 泛型 fn<T> <T>行参
// 我们不自己定义类型,让用用参数的形式告诉函数
// 泛型函数
// 通过函数<行参> 接收传递过来的类型
function getLength<T>(arg: T): T{
return arg
}
interface泛型 泛型默认值
interface IPerspn<T = number, T2 = string> {
name: T2
age: T
run: (value: T) => void
}
let obj: IPerspn = {
name: '小白',
age: 18,
run(value) {
console.log(value);
}
}
常见名称
T: type的缩写 类型
K/V:key和value的缩写 键值对
E:element的缩写 元素
O:object的缩写 对象