前段时间公司项目使用了ts做类型限制,虽然没有深入使用,但是已经能感受到ts的强大。遂将之前的学习笔记整理一遍以作复习。为vue3.0打好基础(大佬们别再学了,跟不上了-_-!!)。

你要知道的

TypeScript是JavaScript的超集,含了 JavaScript 的所有元素,可以载入 JavaScript 代码运行,并扩展了 JavaScript 的语法。
JavaScript是弱类型语言,何为弱类型呢?简单来说就是忽略类型的限制,一个变量可以赋值为任意类型的值。
TypeScript是强类型语言,与弱类型相反,也就是说一个变量声明时指定了类型,那么它就永远是这个类型,只能赋这个类型的值(除非经过强制类型转换)。
JavaScript是脚本语言,TypeScript是编译语言,就是说如果想执行一个ts文件,那么就要先将ts文件编译成js文件再去执行。
使用TS的好处,从现阶段来说,TS带给项目的好处显而易见,首先很多错误在编译阶段就会暴露出来。其次代码有更好的可读性和可维护性。

准备

掌握以下几个命令就可以开始学习TS
全局安装ts
npm i -g typescript
编译ts文件,执行命令后,同目录下会生成一个同名的js文件
tsc xxx.ts
执行
node xxx.js

基础类型

JavaScript的所有类型TS都支持,并且TS还扩展了如枚举等类型。变量的声明方式与JavaScript无异,只是加入了类型注解。
几种常见的类型

let flag: boolean = false // boolean
let num: number = 20 // number
let name: string = 'bob' // string
let list: number[] = [1, 2, 3, 4] // Array
let obj: Object = {} // Object

元组类型
元组就是已知长度和类型的数组

let arr: [string,number]
arr = ['halo', 10] 
arr = [10, 'halo'] // error 赋值的顺序要与声明时的顺序一致,否则会报错
arr[2] = 'wode' // 如此越界赋值,在3.1及以上版本会报错

枚举类型

enum Color1 {
    Red, // 索引默认从0,可以修改
    Green,
    Blue
}
enum Color2 {
    Red = 1, // 索引默认从0,可以修改
    Green = 2,
    Blue = 4
}

let c1: Color1 = Color1.Blue
let colorName: string = Color2[2] // 反查 Green

any任意类型
当不确定类型时可以使用any,表示任意类型

let notSure1: any = 4
let notSure2: any = 'str'
// any 类型的变了可以赋值成任意类型
notSure1 = 'maybe a string inttead'
notSure2 = false
// any 类型的数组,也可以赋值为任意类型
let notSureList: any[] = [1, true, 'dd']
notSureList[1] = 100

需要注意的是,类型注解为any代表任意类型,但是如果不写类型注意,TS会进行类型推断,推断为一个类型,此时该变量是有确定类型的不可随意赋值。如:

let notSure3 = 4 // 不写类型,会根据赋值进行推断,类型为number
notSure3 = 'to string' // error 

void类型
void 表示没有任何类型

// 一个没有返回值的函数
function fn(): void {
    console.log('this fnc has no return');
}

// 对于变量来说,意义不大
let unsable: void = null // 还可以赋值为undefined,赋值其他会报错

null & undefined
赋值成这两种类型没有实际意义

let num: number = 5
num = null // 正常编译不会报错,但是使用 tsc xx.ts --strictNullChecks严格模式编译会报错
// 使用联合类型,联合类型表示或的关系
let num2: number | null = 3
num2 = null

never类型
表示不存在的类型,是所有类型的子类型。never可以赋值给其他类型,其他类型不能赋值给never。

let test1: number = 123
let test2: never
test1 = test2
// test2=test1 // error 

function error(message: string): never {
    throw new Error(message)
}
function fail() {
    return error('some failed')
}

类型断言

有时可以明确指定一个变量为某种类型,类型断言两种常见方式

let someVal: any = 'this is a string'
let strLen1: number = (<string>someVal).length
let strLen2: number = (someVal as string).length

更推荐使用第二种方式。

解构赋值

let o = {
    a1: 'foo',
    b1: 12,
    c1: 'bar'
}
let { a1, b1 }: { a1: string, b1: number } = o;

巴斯光年
274 声望23 粉丝