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;
    }
}

   转载规则


《TypeScript类型断言》 浅夏晴空 采用 知识共享署名 4.0 国际许可协议 进行许可。
 上一篇
nvm版本管理 nvm版本管理
安装nvm首先要安装或者更新nvm,可以使用cURL 使用安装脚本 curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.34.0/install.sh | bash 或者
2019-09-04
下一篇 
node express使用HTML模板 node express使用HTML模板
前言一般我们在做node web项目的时候,想使用我们平时常用的html模板,express默认使用jade模板,本身是没有HTML的,那么如何实现呢? ejs模板配置使用var app = express(); app.set('view
2019-09-04
  目录