小白Ts---入门01

120 阅读2分钟

序章:小白起航,让我们一起来了解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;