当前位置: 首页 > news >正文

外贸网站建站j建设银行成都市第九支行 网站

外贸网站建站j,建设银行成都市第九支行 网站,宣传片素材网站,wordpress文章随机缩略图什么是TypeScript 泛型? 在定义函数,接口,类的时候不能预先确定使用的数据类型,而是在调用使用这些函数,接口,类的时候才能确定的数据类型; 1,单个泛型的参数 例如通过使用any这种…

什么是TypeScript 泛型?

  • 在定义函数,接口,类的时候不能预先确定使用的数据类型,而是在调用使用这些函数,接口,类的时候才能确定的数据类型;

1,单个泛型的参数

例如通过使用any这种方式,value1的类型随着传入的类型数据而变化:

function myfunction01(value1: any, value2: number): any[]{let arr: any[] = [value1, value2]return arr
}
myfunction01('123456', 111);
myfunction01(123456, 111);

改为泛型之后:

function myfunction01<T>(value1: T, value2: T): T[]{// let arr: T[] = [value1, value2]let arr: Array<T> = [value1, value2]return arr
}
myfunction01<string>('123456', '1111');
myfunction01<number>(123456, 111);

2,多个泛型的参数

function myfunction01<T, X>(value1: T, value2: X): [T, X]{return [value1, value2]
}
myfunction01<string, number>('123456', 1111);

3,泛型接口

泛型接口:接口也可以配合泛型来使用,以增加其灵活性,增强其复用性

interface 接口名<类型变量1,类型变量2> {变量:类型变量1,变量:类型变量2
}

使用:

interface MyArray<T> {length: T,data:string[]push(n: T): T,pop(): void,reverse(): T[]
}
const obj: MyArray<number> = {length: 11,push (o){ return o },pop: function () {},reverse: () => [1, 2],data: ['1', '1']
}
  1. 在接口名称的后面添加 <类型变量>,那么,这个接口就变成了泛型接口。
  2. 接口的类型变量,对接口中所有其他成员可见,也就是接口中所有成员都可以使用类型变量。
  3. 使用泛型接口时,需要显式指定具体的类型。

4,泛型工具类型

泛型工具类型:TS 内置了一些常用的工具类型,来简化 TS 中的一些常见操作

说明:它们都是基于泛型实现的(泛型适用于多种类型,更加通用),并且是内置的,可以直接在代码中使用。 这些工具类型有很多,先来学习以下3个:

① Partial

将一个对象类型中的所有属性变为可选属性;

type User = {id: number;name: string;age: number;
}
type UpdatedPerson = Partial<User>;

得到的 UpdatedPerson 类型与下面的类型定义是相同的:

type UpdatedPerson = {id?: number;name?: string;age?: number;
}

② Readonly

将Type 所有属性都设置为 readonly(只读)。

type Props =  {id: stringchildren: number[]
}
type ReadonlyProps = Readonly<Props>

构造出来的新类型 ReadonlyProps 结构和 Props 相同,但所有属性都变为只读的。不可修改

③ Pick

Pick<Type, Keys> 从 Type 中选择一组属性来构造新类型。

type Props = {id: stringtitle: stringchildren: number[]
}
type PickProps = Pick<Props, 'id' | 'title'>
  1. Pick 工具类型有两个类型参数:1 表示选择谁的属性 2 表示选择哪几个属性。 2. 其中第二个类型变量,如果只选择一个则只传入该属性名即可。
  2. 第二个类型变量传入的属性只能是第一个类型变量中存在的属性。
  3. 构造出来的新类型 PickProps,只有 id 和 title 两个属性类型。
http://www.yayakq.cn/news/923739/

相关文章:

  • 部门网站建设的工作汇报自己做家具展示网站
  • 做网站哪里找程序员做网站有哪个空间
  • eclipse做网站代码网站重新搭建程序要多少钱
  • 网站小程序制作公司网址生成二维码在线
  • 为网站营销好处政务网站开发理念
  • 网站设计师是什么专业无锡网站制作哪里实惠
  • 仿站网站域名企业商标图案大全
  • 上海最专业的网站建设公司排名克州seo整站排名
  • 自己申请一个网站怎么做wordpress分享缩略图不显示
  • 相关网站查询微信小程序怎么清理掉
  • 西八里庄网站建设余姚网站定制
  • 网站结合微信大连本地网
  • 做网站公司长沙哪家好网站如果不续费会怎样
  • 免费网站模块wordpress好看的插件
  • 上海好的高端网站建设服务公司wordpress发展现状
  • 国内大的做网站的公司餐饮加盟网站建设方案
  • 网站建设主要包括什么没有域名做网站
  • 织梦配置手机网站苏州建网站哪家
  • 网站建设用什么教材正邦做网站多少钱
  • 南京网站开发南京乐识专心国内公关公司排名
  • 上海做网站的公司是什么企业英文网站建设
  • 合肥专业做网站的公司哪家好佳世达电子 苏州 有限公司
  • 北京公司网站制作费用微信小程序引流推广软件
  • 学做面包的网站wordpress按修改时间排序
  • 南京高端网站开发东莞网站设计方案
  • 公司网站建设怎么入账微信有网页版吗
  • 郴州买房网站亚马逊店铺出售网站
  • 成都网站建设司那个网站专门做幽默视频的
  • 襄阳网站建设首选公司哪家好企业招聘网站
  • 环保网站建设维护情况报告建设我们的网站教案