美文网首页
typescript学习笔记——(一)基础类型

typescript学习笔记——(一)基础类型

作者: _BuzzLy | 来源:发表于2020-04-27 19:07 被阅读0次

    前段时间公司项目使用了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;
    

    相关文章

      网友评论

          本文标题:typescript学习笔记——(一)基础类型

          本文链接:https://www.haomeiwen.com/subject/bhbuwhtx.html