02TypeScript:类型声明和变量类型


1.类型声明

  • 直接在变量声明后面加
let a: number;

a = 10;
a = 'hello'; // 此行代码会报错,但是可以编译成js(也可以设置为报错不能编译成功)
  • 如果变量的声明和赋值是同时进行的,TS可以自动对变量进行类型检测
let c = true;

c = false;
  • 还可以对函数参数和返回值的类型进行声明
function sum(a: number, b: number): number{
	return a + b;
}

2.变量类型

请添加图片描述

  1. number

    let a: number;
    
    a = 10;
  2. string

    let b: string;
    
    b = 'hello';
  3. boolean

    let c= false;
    
    c = true;
  4. 字面量

    let a1: 10;
    
    a1 = 10;//后面使用时不可修改,类似常量
    
    
    //可以使用 | 来连接多个类型(联合类型)
    let b1: "male" | "female";
    b1= "male";
    b1= "female";
    
    let c1 : boolean | string;
    c1 = true;
    c1 = 'hello';
  5. any

    • any 表示的是任意类型,一个变量设置类型为any后相当于对该变量关闭了TS的类型检测
    • 使用TS时,不建议使用any类型(尽量避免)
    // let d:any;(显示的any)
    
    //声明变量如果不指定类型,则TS解析器会自动判断变量的类型为any(隐式的any)
    let d;
    d = 10;
    d = 'hello';
    d = 'true';
  6. unknown

    • unknown 实际上就是一个类型安全的any
    • unknown 类型的变量,不能直接赋值给其他变量
    //unknown表示未知类型的值
    let e: unknown;
    e = 10;
    e = true;
    e = "hello";

    any类型的变量可以赋值给任意变量;但unknown 类型的变量不能直接赋值给其他变量

    let s:string;
    
    //d的类型是any,它可以赋值给任意变量
    let d;
    s = d;
    
    let e: unknown;
    e = 'hello';
    s = e;//会报错,e的类型是unknown,不能直接赋值给其他变量
    
    if (typeof e === "string") {
        s = e;
    }

    类型断言—可以用来告诉解析器变量的实际类型

    /*
    语法:
        变量 as 类型
        <类型>变量
    */
    s = e as string;
    s = <string>e;
  7. void

    void 用来表示空值,以函数为例,就表示没有返回值(或返回undefined)的函数

    function fn2(): void{
    
    }
  8. never

    never 表示永远不会返回结果;没有值(比较少用,一般是用来抛出错误)

    function fn3(): never{
        throw new Error("报错了!");
    }
  9. object

    1.{ } 用来指定对象中可以包含哪些属性

/*  
    语法:{属性名:属性值,属性名:属性值}
    在属性名后面加上?,表示属性是可选的
*/
let b: {name: string, age?:number};

b = {}; //没有的话就会报错
b = {name: "孙悟空", age: 18};

let c1: {name: string, a?:number, b?:number};
c1 = {name:"猪八戒", a:1, b:2,c:3} //会报错,多余了c
2.[propName: string]: any 表示可以多余任意类型的属性
let c: {name: string, [propName: string]: any}
c = {name:"猪八戒", age: 18, gender: '男'}

设置函数结构的类型声明

/* 
    语法: 
    	(形参:类型,形参:类型...)=> 返回值
*/
let d1: (a: number ,b: number)=>number;

d1 = function (n1: number, n2: number): number {
    return n1 + n2
}
  1. array

    /* 
        数组的类型声明:
            类型[]
            Array<类型>
    */
    
    //string[] 表示字符串数组
    let e1:string[];
    e1 = ['a','b','c'];
    
    //number[] 表示数值数组
    let f: number[];
    
    let g: Array<number>;
    g = [1, 2, 3];
  2. tuple(ts新增类型)

    tuple(元组):就是固定长度的数组

    /* 
        语法:[类型, 类型, 类型]
    */
    
    let h: [string, number];
    h = ['hello', 123];
  3. enum(ts新增类型)

    枚举可以把所有可能的值都列举出来

    enum Gender{ //定义枚举类型可以把所有可能的值都列举出来
        Male = 0,
        Female = 1,
    }
    
    let i: {name: string, gender: Gender};
    i = {
        name: '孙悟空',
        gender: Gender.Male
    }
    
    console.log(i.gender === Gender.Male)

    & 表示同时满足

    let j: {name: string} & {age: number};
    j = {name: '孙悟空', age:18}

    类型的别名

    type myType = 1 | 2 | 3 | 4 | 5;
    let k: myType;
    let l: myType;
    let m: myType;
    
    k = 2;

文章作者: Bertil Chan
版权声明: 本博客所有文章除特別声明外,均采用 CC BY 4.0 许可协议。转载请注明来源 Bertil Chan !
  目录