ts 泛型 泛型约束 typeof keyof

/泛型

 //两个函数只是定义类型不一样,功能一样,可优化
 function  num(a:number,b:number):Array<number>{
     return [a,b]
 }

 num(2,5)

 function str(a:string,b:string):Array<string>{
     return [a,b]
 }

 str('今天','周二')



 //泛型优化

 function Add<T>(a:T,b:T):Array<T>{
     return [a,b]
 }
Add<number>(1,2)
Add<string>('1','2')

//同时也可以使用参数类型不同

function Addy<T,Y>(a:T,b:Y):Array<T | Y>{
    return [a,b]
}
Addy<number,string>(1,'2')

type A<T> = string | number | T

let A:A<null> = null
let AB:A<string> = '1'




//定义泛型接口
interface smile<T>{
    msg:T
}

let data:smile<number> = {
    msg:1
}

//泛型约束

function AddN<T extends number>(a:T,b:T) {
    return a + b
}

AddN(2,6)


interface  Student{
    name:String,
    age:Number,
    class:Number
}




type Options <T extends Object> = {
     [key in keyof T ]? : T[key]
}

type AD = Options<Student>


// keyof : 获取对象的key组成的联合类型

//typeof是 根据已有的值 来获取值的类型

const a ={name:"张三",age:18}
type keyofa =keyof typeof a

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值