在TypeScript中,提供了一下基本数据类型
其中元组、枚举、任意值、void类型和 never类型是TypeScript有别与JavaScript的特有类型。
在TypeScript中声明变量,需要加上类型声明,例如boolean和string等。通过静态类型约束,在编译时执行类型检查,可以避免一些类型混用的低级错误。
布尔类型
布尔类型是最简单的数据类型,只有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 属性时就报错了。