ts 之 泛型

泛型的基本使用

//不明确name的类型时使用
//表示定义了一个泛型T,然后传参name是T类型,myFun的返回值也是T类型;当myFun被调用时才能确定T的值
function myFun<T>(name: T): T {
    return name
}

myFun<string>('hellow')//T为string类型
myFun<number>(15)//T为number类型

泛型可以同时指定多个

function myFun<T, K>(name: T, age: K): T{
    return name
}
myFun<string, number>('tt', 18)//T为string类型,K为number类型

泛型结合interface

interface Inter{
    length: number
}

//T extends Inter 表示泛型T必须是Inter的子类
function myFum<T extends Inter>(value: T): number{
    return value.length
}

myFum('abc')//'abc'.length 字符串有length属性,符合Inter接口规范
myFum([1,3,9,5,])//[1,3,9,5,].length 数组有length属性,符合Inter接口规范
myFum({length: 5})//{length: 5}.length 该对象有length属性,符合Inter接口规范

泛型结合class

class myClass<T>{
    name: T
    constructor(name: T){
        this.name = name
    }
}

const my = new myClass<string>('tm')
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值