乐趣区

TypeScript类型断言

类型断言

类型断言(Type Assertion)可以用来手动指定一个值的类型。

语法

< 类型 > 值 或者 
值 as 类型 

在 tsx 语法(React 的 jsx 语法的 ts 版)中必须用后一种。

示例

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

//string 和 number 都有 toString 方法
getLen = (something: string|number) => {return something.toString();
}
//Property 'length' does not exist on type 'ReactText'.
  Property 'length' does not exist on type 'number'.
getLen = (something: string|number) => {return something.length;}

而有时候,我们确实需要在还不确定类型的时候就访问其中一个类型的属性或方法,比如:

//Property 'length' does not exist on type 'ReactText'.
  Property 'length' does not exist on type 'number'.
getLen = (something: string|number) => {if(something.length){return something.length;}else{return something.toString().length;
    }
}

此时可以使用类型断言,将 something 断言成 string

//tsx 文件中用 <> 方式报错
//Property 'string' does not exist on type 'JSX.IntrinsicElements'.ts(2339)
//JSX element 'string' has no corresponding closing tag.
getLen = (something: string|number) => {if ((<string>something).length) {return (<string>something).length;
    } else {return something.toString().length;
    }
}
用 as 方式 相当于 js 的 typeof
getLen = (something: string|number) => {if ((something as string).length) {return (something as string).length;
    } else {return something.toString().length;
    }
}
退出移动版