前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >浅谈TypeScript泛型T和any的区别

浅谈TypeScript泛型T和any的区别

作者头像
青年码农
发布2022-08-19 11:01:35
1.9K0
发布2022-08-19 11:01:35
举报
文章被收录于专栏:青年码农

点击上方“青年码农”关注

回复“特效源码”可获取各种资料

当我们定义一个变量或者重构之前的JavaScript代码不确定类型的时候,一般会有两种解决方式。

1. 使用any

简单粗暴,任何类型都可以,但是失去了ts类型保护的优势。

2. 使用泛型

不预先指定具体的类型,而是在使用的时候在指定类型限制的一种特性。

看下面的这个函数

代码语言:javascript
复制
function identity(arg: any): any {
    return arg;
}

identity这个函数接收一个参数,这个参数是任意类型,返回的结果也是任意类型.。如果这个函数的传入的类型和返回的类型相同,使用any类型,就无法实现这个约束。

因此,需要一种方法使返回值的类型与传入参数的类型是相同的。这里,我们使用了类型变量,它是一种特殊的变量,只用于表示类型而不是值。

代码语言:javascript
复制
function identity<T>(arg: T): T {
    return arg;
}

没有明确要求传递参数的类型,虽然也是任意类型,但是保证了传入类型和返回类型的一致性。

代码语言:javascript
复制
let output = identity<string>("myString"); 

使用<>明确string类型,作为参数传给函数。另外一种是类型推论,这种方法更普遍,

代码语言:javascript
复制
let output = identity("myString");

调用函数我们没有明确传入的类型,编译器帮我们去识别,并设置它的类型。如果复杂的情况,编译器不能自动判断类型的话,那就需要我们手动设置。

通过上面简单的例子,我们可以很好的理解这两个区别,打个比方,你去超市买东西,你给的是钱,售货员给你的是商品,类型不同,可以用any。如果你去超市破零钱,那售货员给你的还是钱,类型相同,可以用泛型<T>。

any就不用过多讲解使用方式,和其他类型一样,主要说说泛型的使用

1.在函数中使用

代码语言:javascript
复制
function echo<T>(arg:T):T{
    return arg
}
const result=echo(true)

很好理解,给的什么,返回的就是什么。

代码语言:javascript
复制
function swap<T,U>(arg:[T,U]):[U,T]{
    return [arg[],arg[]]
}
const result2=swap(['string',])

和上面类似,传递两个参数,返回时做了调换。

2.在类中使用

代码语言:javascript
复制
class Animal<T> {
 name:T;
 constructor(name: T){
  this.name = name;
 }
 action<T>(say:T) {
   console.log(say)
 }
}
let cat = new Animal('cat');
cat.action('mimi')

实例化Animal的时候,传递的参数是string类型,因此在调用cation方法时也要是相同的类型。

3.在接口中使用

代码语言:javascript
复制
interface KeyPair<T,U>{
    key:T,
    value:U
}
let kp1:KeyPair<number,string>={key:,value:'string'}
let kp2:KeyPair<string,number>={key:'abc',value:}
本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2022-07-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 青年码农 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档