TypeScript泛型

泛型 泛指所有类型 

我们不自己定义类型,让用户用参数的形式告诉函数

需求一个函数传递过来什么类型就返回什么类型

// 不确定用户传递什么类型的参数回来,那么也就不能确定返回值
 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的缩写 对象

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值