美文网首页我爱编程
TypeScript 学习笔记 之 枚举与类型推断

TypeScript 学习笔记 之 枚举与类型推断

作者: 一半晴天 | 来源:发表于2018-03-07 16:31 被阅读234次

枚举

  1. 默认枚举属性的值为整型,且从0开始自动递增, 如下:
enum Direction{
  Up,Down,Left,Right,
}
  1. 也可以指定值。如指定 Up = 1 ,以便枚举从1 开始。

  2. 也枚举值也支持字符串类型:

enum Direction{
 Up = "UP",Down = "DOWN",Left="LEFT",Right="RIGHT",
  1. 由于 JS 类型的灵活性也支持混合类型的枚举成员,但是一定不推荐这样做。

  2. 枚举不仅支持常量值也支持编译期可计算的值。
    如:

  1. 引用了其他的枚举常量。
    2)括号内的枚举常量表达式。
  2. 使用了 +,-,~ 一元操作符的枚举常量值。
  3. 使用了 +,-,*,/,%,<<,>>,&,|,^ 二元操作符的枚举常量表达 式。
  1. 某些枚举成员也可以当类型使用,示例如下:
enum ShapeKind{
  Circle,
  Square,
}
interface Circle{
  kind: ShapeKind.Circle;
  radius:number;
}
interface Square{
  kind: ShapeKind.Square;
  sideLength: number;
}
  1. 枚举成员也可以当对象使用,因为它在运行期的确是有对应存在的。

  2. 对于数值类型的枚举,以枚举成员作为属性访问枚举类可以获得对应的枚举成员的属性名。

  3. const 枚举。声明为 const 的枚举只存在于编译期,生成的代码中将删除。

  4. Ambient 枚举。用于描述在其他地方已经存在的枚举类型。

declare enum Enum{
  A = 1,
  B,
  C = 2
}

类型推断

  1. 基本推断 let x = 3; 意味着 let x:number = 3;

  2. 最佳公共类型推断对于字面量包含多个值时(比如数组),自动推断的类型有可能是他们的共同的父类型,或者一个联合类型。

  3. 上下文类型,例如下面的代码,可以推断出 moveEvent 没有 button 属性。

window.onmousedown = function(mouseEvent){
  console.log(mouseEvent.button); // <- Error
}

相关文章

网友评论

    本文标题:TypeScript 学习笔记 之 枚举与类型推断

    本文链接:https://www.haomeiwen.com/subject/namjfftx.html