序章:小白起航,让我们一起来了解TypeScript。
1、基础类型
1.1 布尔值(Boolean)
let isDone: boolean = false; // 声明类型
let isDone = true; // 隐式声明为Boolean类型
isDone = 1; // Type 'number' is not assignable to type 'boolean'
console.log("Boolean", isDone);
1.2 数字(Number)
除了支持十进制和十六进制字面量,TypeScript还支持ECMAScript 2015中引入的二进制和八进制字面量。
let num1: number = 6;
let num1 = 6;
let hexLiteral: number = 0xf00d;
let binaryLiteral: number = 0b1010;
let octalLiteral: number = 0o744;
console.log("Number", num1, hexLiteral, binaryLiteral, octalLiteral);
1.3 字符串(String)
let name: string = "bob";
name = "smith";
// 可以使用模版字符串
let age: number = 37;
let sentence: string = `Hello, name is ${ name } age: ${ age }`;
console.log("String", name, sentence);
1.3 数组(Array)
// 第一种: 可以在元素类型后面接上 []
let list1: number[] = [1, 2, 3];
// 第二种: 是使用数组泛型,Array<元素类型>
let list2: Array<number> = [1, 2, 3];
console.log("Array", list1, list2);
1.4 元组 Tuple
let x: [string, number];
x = ["hello", 10]; // OK
// x = [10, 'hello']; // Error
console.log("Tuple", x);
1.5 枚举
// enum Color {Red, Green, Blue}
enum Color {"红色"= 1, "绿色"= "green", "蓝色"= "blue"};
let c: Color = Color["红色"];
let cName: string = Color[2];
console.log("enum", c, cName);
1.6 Any(不指定类型,动态设置)
let notSure: any = 4;
notSure = false;
notSure = "string";
let list: any[] = [1, true, "free"];
console.log("Any", notSure, list);
1.7 Void (没有任何类型)
只能为它赋予undefined和null, 单独声明一个void类型的变量没有什么大用
let unusable: void = undefined;
function warnUser(): void {
console.log("This is my warning message");
}
1.8 Null 和 Undefined
undefined和null两者各自有自己的类型分别叫做undefined和null。 和 void相似,它们的本身的类型用处不是很大
let u: undefined = undefined;
let n: null = null;
console.log(`Null:${n}-----Undefined: ${u}`);
1.9 Never 表示的是那些永不存在的值的类型
never类型是任何类型的子类型,也可以赋值给任何类型;然而,没有类型是never的子类型或可以赋值给never类型(除了never本身之外)。 即使 any也不可以赋值给never。 返回never的函数必须存在无法达到的终点
function error(message: string): never {
throw new Error(message);
}
1.10 Object
object表示非原始类型,也就是除number,string,boolean,symbol,null或undefined之外的类型
function create(o: object | null): void {
console.log(o);
};
create({ prop: 0 }); // OK
create(42); // Error
1.11 类型断言
当你在TypeScript里使用JSX时,只有 as语法断言是被允许的。
let someValue: any = "this is a string";
// 第一种:“尖括号”语法
let strLength1: number = (<string>someValue).length;
// 第二种:as语法
let strLength2: number = (someValue as string).length;