TypeScript中的类型断言

2019-06-2867次阅读TypeScript

TypeScript中的类型断言简略的定义是可以用来手动指定一个值的类型,有两种写法:尖括号和as

let someValue: any = "this is a string";
let strLength: number = (<string>someValue).length;
let strLength: number = (someValue as string).length;

当TypeScript不确定一个联合类型的变量到底是哪个类型的时候,我们只能访问此联合类型的所有类型里共有的属性或方法:

function getLength(something: string | number): number {
    return something.length;
}

// index.ts(2,22): error TS2339: Property 'length' does not exist on type 'string | number'.
//   Property 'length' does not exist on type 'number'.

有时候,我们确实需要在还不确定类型的时候就访问其中一个类型的属性或方法,此时需要断言才不会报错:

function getLength(something: string | number): number {
    if ((<string>something).length) {
        return (<string>something).length;
    } else {
        return something.toString().length;
    }
}

 

上一篇: JavaScript设计模式之装饰者模式  下一篇: TypeScript中interface和type简介  

TypeScript中的类型断言相关文章