TypeScript高手密技:解密类型断言、非空断言与 `const` 断言

什么是类型断言?

TypeScript 允许你覆盖它的推断,并且能以你任何你想要的方式分析它,这种机制被称为「类型断言」。 TypeScript 类型断言用来告诉编译器你比它更了解这个类型,并且它不应该再发出错误。

如何使用类型断言?

TypeScript提供了两种语法:

  1. as 语法(推荐)

    typescript 复制代码
    let someValue: unknown = "this is a string";
    let strLength: number = (someValue as string).length;
  2. 尖括号语法

类似于那些静态语言的类型转换

ini 复制代码
```typescript
let someValue: unknown = "this is a string";
let strLength: number = (<string>someValue).length;
```

高级断言技巧

  1. 非空断言操作符(!

    当你非常确定一个值不是nullundefined时,可以在变量或表达式后使用!

    typescript 复制代码
    function process(user: User | null) {
      // 编译器会报错,因为 user 可能为 null
      // console.log(user.name);
    
      // 我确信在调用这个函数时,user 绝不为 null
      console.log(user!.name); 
    }

    警告: 这是在手动关闭TypeScript的一个重要安全检查。请仅在你100%确定该值非空的情况下使用,否则它会隐藏潜在的null引用错误,直到运行时才爆发。

  2. const 断言 (as const)

    这是一个非常强大的工具,用于告诉TypeScript将一个表达式推断为最具体、最不可变的类型。

    • 对于字面量 :类型将是字面量本身,而不是通用的stringnumber
    • 对于对象 :所有属性都会变成readonly
    • 对于数组 :会变成readonly元组(tuple)。
    typescript 复制代码
    // 没有 as const
    let config = { url: '/api/data', method: 'GET' };
    // config 类型: { url: string; method: string; }
    
    // 使用 as const
    let constConfig = { url: '/api/data', method: 'GET' } as const;
    // constConfig 类型: { readonly url: "/api/data"; readonly method: "GET"; }
    
    // 对于数组
    let permissions = ['read', 'write'];
    // permissions 类型: string[]
    
    let constPermissions = ['read', 'write'] as const;
    // constPermissions 类型: readonly ["read", "write"]

何时避免使用断言?

  1. 优先使用类型守卫(Type Guards)typeofinstanceofin 操作符或自定义的is谓词函数是更安全的选择,因为它们会在运行时进行检查,并在此基础上智能地收窄类型。

    typescript 复制代码
    // 不推荐的方式
    function printLength(value: string | string[]) {
      if ((value as string).length) { // 危险的断言
        console.log((value as string).length);
      } else {
        console.log((value as string[]).length);
      }
    }
    
    // 推荐的方式:使用类型守卫
    function printLengthSafe(value: string | string[]) {
      if (typeof value === 'string') {
        console.log(value.length); // value 在这里是 string 类型
      } else {
        console.log(value.length); // value 在这里是 string[] 类型
      }
    }
  2. 避免 as anyas any 是最后的手段,它会完全关闭对该变量的类型检查。

总结

如果你喜欢本教程,记得点赞+收藏!关注我获取更多JavaScript/TypeScript开发干货

相关推荐
Winson℡20 分钟前
React Native 中的 useCallback
javascript·react native·react.js
wyzqhhhh22 分钟前
less和sass
前端·less·sass
Nan_Shu_6142 小时前
学习:uniapp全栈微信小程序vue3后台-额外/精彩报错篇
前端·学习·微信小程序·小程序·uni-app·notepad++
excel3 小时前
Vue3 中的双向链表依赖管理详解与示例
前端
谢尔登3 小时前
【Nest】基本概念
javascript·node.js·express
前端小白从0开始3 小时前
Chrome DevTools高级用法:性能面板内存泄漏排查
前端·chrome·chrome devtools
EveryPossible3 小时前
带有渐变光晕
前端·javascript·css
jojo是只猫4 小时前
Vue 3 开发的 HLS 视频流播放组件+异常处理
前端·javascript·vue.js
卓码软件测评4 小时前
第三方软件登记测试机构:【软件登记测试机构HTML5测试技术】
前端·功能测试·测试工具·html·测试用例·html5
CS Beginner4 小时前
【html】canvas实现一个时钟
前端·html