Typescript:基本类型

介绍

在TypeScript中,提供了以下基本数据类型:

  • 布尔类型
  • 数字类型
  • 字符串类型
  • 数组类型
  • 元组类型
  • 枚举类型
  • 任意值类型
  • null和undefined
  • void类型
  • never类型

其中元组、枚举、任意值、void类型和never类型是TypeScript有别于JavaScript的特有类型。

布尔类型

布尔类型是最简单的数据类型,只有true和false两种值。下面定义了一个布尔类值的变量flag,并赋值为true。由于flag被初始化为布尔类型,如果再赋值为非boolean的其他类型值,编译时会抛出错误。

let flag:boolean = true;
flag = 1; //报错,不能把数字类型的值赋给布尔类型的变量。

数字类型

在TypeScript中,数字都是浮点型。TypeScript同时支持二进制、八进制、十进制和十六进制字面量,示例代码如下:

let binaryLiteral:number = 0b1010;//二进制
let octalLiteral:number = 0o744;//八进制
let decLiteral:number = 6;十进制
let hexLiteral:number = 0xf00d;//十六进制

字符串类型

TypeScript支持使用单引号(‘)或者双引号(“)来表示字符串类型。除此之外,还支持使用模版字符串反引号(`)来定义多行文本和内嵌表达式。使用${expr}的形式嵌入变量或者表达式,在处理拼接字符串的时候很有用,示例代码如下。

let name: string = "Angular";
let years:number = 5;
let words:stirng = `你好,今年是${name}发布${years+1}周年`;

数组类型

TypeScript像JavaScript一样可以操作数组元素。 有两种方式可以定义数组。

第一种,可以在元素类型后面接上 [],表示由此类型元素组成的一个数组:

let list: number[] = [1, 2, 3];

第二种方式是使用数组泛型,Array<元素类型>:

let list: Array<number> = [1, 2, 3];

元组类型

元组类型用来表示已知元素数量和类型的数组,各元素的类型不必相同,下面定义了一对值分别为字符串和数字类型的元组。

let x:[string,number];
x = ["Angular",24];

x = [10,"Angular"];//报错

console.log(x[0]);  //输出Angular

枚举类型

枚举是一个可被命名的整型常数的集合,枚举类型为集合成员赋予有意义的名称,增强可读性。

enum Color {Red, Green, Blue}
let c: Color = Color.Blue;
console.log(c);//输出:2

枚举默认下标是0,可以手动修改默认下标值

enum Color {Red=2, Blue, Green=6}
let c: Color = Color.Blue;
console.log(c);//输出:3

任意值类型

任意值是TypeScript针对编程时类型不明确的变量使用的一种数据类型,它常用于以下二种情况。

① 变量的值动态变化时,比如来自用户的输入或者第三方代码库,任意值类型可以让这些变量跳过编译阶段的类型检查

let x:any = 1;//数字类型
x = "I am a string"; //字符串类型
x = false; //布尔类型

② 定义存储各种类型数据的数组时

let arrayList:any[] = [1,falses,"fine"];
arrayList[1] = 100;

Void

function warnUser(): void {
    alert("This is my warning message");
}

声明一个void类型的变量没有什么大用,因为你只能为它赋予undefined和null:

let unusable: void = undefined;
let unusable: void = null;

Null 和 Undefined

TypeScript里,undefined和null两者各自有自己的类型分别叫做undefined和null。 和 void相似,它们的本身的类型用处不是很大:

let u: undefined = undefined;
let n: null = null;

undefined 类型的变量只能被赋值为 undefined,null 类型的变量只能被赋值为 null。

与 void 的区别是,undefined 和 null 是所有类型的子类型。也就是说 undefined 类型的变量,可以赋值给 number 类型的变量,但是尽量不要这么用。

// 这样不会报错
let num: number = undefined;

// 这样也不会报错
let u: undefined;
let num: number = u;

而 void 类型的变量不能赋值给 number 类型的变量:

let u: void;
let num: number = u;

// index.ts(2,5): error TS2322: Type 'void' is not assignable to type 'number'.

类型推论

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

let myFavoriteNumber = 'seven';
myFavoriteNumber = 7;

// index.ts(2,1): error TS2322: Type 'number' is not assignable to type 'string'.

事实上,它等价于:

let myFavoriteNumber: string = 'seven';
myFavoriteNumber = 7;

// index.ts(2,1): error TS2322: Type 'number' is not assignable to type 'string'.

联合类型

联合类型(Union Types)表示取值可以为多种类型中的一种。

let myFavoriteNumber: string | number;
myFavoriteNumber = 'seven';
myFavoriteNumber = 7;
let myFavoriteNumber: string | number;
myFavoriteNumber = true;

// index.ts(2,1): error TS2322: Type 'boolean' is not assignable to type 'string | number'.
//   Type 'boolean' is not assignable to type 'number'.

联合类型使用 | 分隔每个类型。

这里的 string | number 的含义是,允许 myFavoriteNumber 的类型是 string 或者 number,但是不能是其他类型。

联合类型的属性或方法

当 TypeScript 不确定一个联合类型的变量到底是哪个类型的时候,我们只能访问此联合类型的所有类型里共有的属性或方法

function getLength(something: string | number): number {
  return something.length;
}

// index.ts(2,20): error TS2339: Property 'length' does not exist on type 'string | number'.
//   Property 'length' does not exist on type 'number'.

上例中,length 不是 string 和 number 的共有属性,所以会报错。

访问 string 和 number 的共有属性是没问题的:

function getString(something: string | number): string {
  return something.toString();
}

联合类型的变量在被赋值的时候,会根据类型推论的规则推断出一个类型:

let myFavoriteNumber: string | number;
myFavoriteNumber = 'seven';
console.log(myFavoriteNumber.length); // 5
myFavoriteNumber = 7;
console.log(myFavoriteNumber.length); // 编译时报错

// index.ts(5,30): error TS2339: Property 'length' does not exist on type 'number'.

上例中,第二行的 myFavoriteNumber 被推断成了 string,访问它的 length 属性不会报错。

而第四行的 myFavoriteNumber 被推断成了 number,访问它的 length 属性时就报错了。

    原文作者:whyneedname
    原文地址: https://segmentfault.com/a/1190000011197554
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞