设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 文件
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

一文学懂TypeScript的类型(4)

发布时间:2019-03-21 23:50 所属栏目:21 来源:疯狂的技术宅
导读:你可以看到类型参数 T 在 Stack 的主体内出现两次。因此,该接口可以直观地理解如下: Stack 是一堆值,它们都具有给定的类型 T。每当你提到 Stack 时,必须写 T。接下来我们会看到究竟该怎么用。 方法 .push() 接

你可以看到类型参数 T 在 Stack 的主体内出现两次。因此,该接口可以直观地理解如下:

  •  Stack 是一堆值,它们都具有给定的类型 T。每当你提到 Stack 时,必须写 T。接下来我们会看到究竟该怎么用。
  •  方法 .push() 接受类型为 T 的值。
  •  方法 .pop() 返回类型为 T 的值。

如果使用 Stack,则必须为 T 指定一个类型。以下代码显示了一个虚拟栈,其唯一目的是匹配接口。

  1. const dummyStack: Stack<number> = {  
  2.   push(x: number) {},  
  3.   pop() { return 123 },  
  4. }; 

例子:map

map 在 TypeScript 中的定义。例如:

  1. const myMap: Map<boolean,string> = new Map([  
  2.   [false, 'no'],  
  3.   [true, 'yes'],  
  4. ]); 

函数的类型变量

函数(和方法)也可以引入类型变量:

  1. function id<T>(x: T): T {  
  2.   return x;  

你可以按以下方式使用此功能。

  1. id<number>(123); 

由于类型推断,还可以省略类型参数:

  1. id(123); 

传递类型参数

函数可以将其她的类型参数传给接口、类等:

  1. function fillArray<T>(len: number, elem: T) {  
  2.   return new Array<T>(len).fill(elem);  

类型变量 T 在这段代码中出现三次:

  •  fillArray<T>:引入类型变量
  •  elem:T:使用类型变量,从参数中选择它。
  •  Array<T>:将 T 传递给 Array 的构造函数。

这意味着:我们不必显式指定Array<T>的类型 T —— 它是从参数 elem中推断出来的:

  1. const arr = fillArray(3, '*');  
  2.   // Inferred type: string[] 

总结

让我们用前面学到的知识来理解最开始看到的那段代码:

  1. interface Array<T> {  
  2.   concat(...items: Array<T[] | T>): T[];  
  3.   reduce<U>(  
  4.     callback: (state: U, element: T, index: number, array: T[]) => U,  
  5.     firstState?: U): U;  
  6.   ···  

这是一个Array的接口,其元素类型为 T,每当使用这个接口时必须填写它:

  •  方法.concat()有零个或多个参数(通过 rest 运算符定义)。其中每一个参数中都具有类型 T[]|T。也就是说,它是一个 T 类型的数组或是一个 T 值。
  •  方法.reduce() 引入了自己的类型变量 U。 U 表示以下实体都具有相同的类型(你不需要指定,它是自动推断的):
    •   Parameter state of callback() (which is a function)
    •   state 是 callback() 的参数(这是一个函数)
      •   Result of callback() 
    •   callback()的返回
    •    reduce()的可选参数 firstState
      •   Result of .reduce() 
    •    reduce()的返回

callback 还将获得一个 element 参数,其类型与 Array 元素具有相同的类型 T,参数 index 是一个数字,参数 array 是 T 的值。

【责任编辑:庞桂玉 TEL:(010)68476606】
点赞 0

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读