ts泛型

泛型

在定义函数、接口或者类的时候、不需要先指定具体类型、而在用的时候再指定类型的一种特性。
其实就是把类也当作变量(类是可变的,未知的)使用,把类放在<>尖括号内,表示声名的类型。

  • 定义 function 函数名<类型变量声明>(length: number, value: 类型变量): Array<类型变量> {}
  • 如:
    function 函数名(length: number, value: T): Array {};其中T就是类型的变量名;调用 函数名(参数) //给变量T赋值为string。

1、函数里使用泛型

function fun<T>(a:number,b:T):any{
    return a+"----"+b
}
let demo1=fun<string>(8,"哈哈")
console.log(demo1)//8----哈哈

2、类里面使用泛型

class Person1<T,S>{
    name:T;
    sex:S;
    age:number
    constructor(name,sex,age){
        this.name=name;
        this.sex=sex;
        this.age=age;
    }
}
let demo2=new Person1<string,number>("张三","name",18)
console.log(demo2)//Person1 {name: "张三", sex: "男", age: 18}

注意看与上面不同的地方

class Person1<T,S>{
    name:T;
    sex:S;
    age:number
    constructor(name:T,sex,age:number){
        this.name=name;
        this.sex=sex;
        this.age=age;
    }
}
let demo2=new Person1<string,number>("张三","男",18)
console.log(demo2)//Person1 {name: "张三", sex: "男", age: 18}
相关推荐

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
©️2022 CSDN 皮肤主题:游动-白 设计师:我叫白小胖 返回首页

打赏作者

果冻~

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值