1 数据类型

支持js的数据类型,并增加枚举类型

1.1 基本类型

  1. // 布尔类型
  2. let isDone: boolean = false;
  3. // number类型
  4. let student: number = 6;
  5. // str类型
  6. let name: str = "tom";
  7. // 数组类型,可用两种方式
  8. let list:number[] = [1,2,4] // 元素类型+[]
  9. let list:Array<nmuber> = [1,2,4] // 数组泛型 既Array[元素类型]
  10. // Null 和 Undefined , undefined 和 null 是所有类型的子类型
  11. let u: undefined = undefined;
  12. let n: null = null;
  13. // 这样不会报错
  14. let num: number = undefined;
  15. // 空值
  16. function alertName(): void {
  17. alert('My name is Tom');
  18. }

1.2 任意类型Any

如果是 any 类型,允许被赋值为任意类型. 并且允许访问其任何属性和方法

  1. let a:any = 'a'
  2. a = 7
  3. a.sayhello()
  4. // 声明一个变量为任意值之后,对它的任何操作,返回的内容的类型都是任意值
  5. a.sayhello().name

2 类型推论

如果没有明确的指定类型,那么 TypeScript 会依照类型推论(Type Inference)的规则推断出一个类型。
以下代码虽然没有指定类型,但是会在编译的时候报错:

  1. let myFavoriteNumber = 'seven';
  2. myFavoriteNumber = 7;
  3. // index.ts(2,1): error TS2322: Type 'number' is not assignable to type 'string'.

事实上,它等价于:

  1. let myFavoriteNumber: string = 'seven';
  2. myFavoriteNumber = 7;
  3. // index.ts(2,1): error TS2322: Type 'number' is not assignable to type 'string'.

TypeScript 会在没有明确的指定类型的时候推测出一个类型,这就是类型推论。

如果定义的时候没有赋值,不管之后有没有赋值,都会被推断成 any 类型而完全不被类型检查

  1. let myFavoriteNumber;
  2. myFavoriteNumber = 'seven';
  3. myFavoriteNumber = 7;