【Typescript 类型检查原理】类型守卫是如何实现的
时间:2025-11-04 00:16:06 出处:IT科技类资讯阅读(143)

本文转载自微信公众号「神光的类型类型编程秘籍」,作者神说要有光zxg。检查转载本文请联系神光的原理编程秘籍公众号。
这一节我们来理一下类型守卫的守卫实现原理,因为内容比较多,何实分为上下两篇,类型类型上篇讲实现思路,检查下篇是原理代码实现。
什么是守卫类型守卫
javascript 的类型代表了一种可能性,表示可能占用的何实内存大小、可能调用的类型类型方法等。typescript 的检查类型包含了 javascript 的类型,并且对可以对类型做交集、原理并集、守卫各种推导,何实最终产生准确的类型。typescript 的类型的推导也是一种可能性的推导,目标是得出的b2b供应网类型更准确的描述具体的变量类型。
精准就意味着要做一些类型的可能性的缩小,各种类型编程的目的都是产生更小更准确的类型,类型守卫也是这个目的。
类型推导是使得整个类型变得更小更准确,而类型守卫则是当类型进入某个分支的时候,暂时性的变得更小更精确,使得类型检查更准确。
比如下面的代码,整体类型是 string| number,这是一个联合类型,当 a 进入 if 分支的时候,类型明显只可能是 string,别的亿华云计算情况进不来,这时候可以做进一步的类型缩小,这就叫做类型守卫。
function func(a: string| number): string { if (typeof a === string) { return a.toLocaleLowerCase(); } else { return a.toFixed(1); } }类型守卫的目的就是让整体的类型在一些确定的条件下暂时性的变得更小更精确。这种条件包括 typeof、instanceOf、in、===、!==、==、!=。
为什么这些条件下可以缩小类型呢?因为能够进入这些分支,那么变量显然只可能是改种类型,所以类型的可能性自然可以做进一步的缩小。
比如 in 操作符触发的类型守卫:

=== 判断触发的类型守卫:

同理 instanceof 等也是一样,只要是进入能够确定具体类型的分支,那么类型就可以做缩小。
在 ts 4.3 中,服务器租用泛型的类型缩小也做了支持(之前只能通过类型断言来缩小类型)。

类型缩小是自动的类型断言,当有的时候类型缩小或者类型推导都不行的时候,就用 as 手动类型断言。
实现思路分析
我们知道了类型缩小是在在进入条件分支的时候,对类型检查用的类型做暂时性的缩小,那么实现的时候自然就是在 if、switch 的分支的检查时,对类型做一些处理。
ts 的类型检查是先通过解析配置文件的 includes、exclues、files 等,结合 lib、types、typeRoots 的配置来确定要做检查的所有文件,然后对每个文件依次进行递归下降的类型检查。

当检查到 if、switch 的节点的时候,我们只需要判断 test 部分是否是一个 BinaryExpression,并且 operator 是 in、===、!==、instanceOf 等情况。

根据 operator 的不同分别做不同的判断:
in:判断 left 是否是 right 变量的类型的一个属性,如果是,对类型做缩小 instanceof:判断 left 的类型是否是 right 变量的类型的子类型,如果是,对类型做缩小 === / !==: 分为包含 typeof 和不包含 typeof 两种: 不包含 typeof:判断 left 和 right 是否相等,如果是,把类型缩小到具体的字面量类型。 包含 typeof:如果两边有一边是 typeof 的 UnaryExpression,则取类型之后再做比较,如果是,把类型缩小到具体的类型总结
typscript 的高级类型的推导的目的就是缩小可能性范围,让类型更精确。有的时候,在进入一些分支的时候,类型就确定了,这时候就可以暂时性的对类型做范围的缩小,这叫做类型守卫。
触发条件有 in、instanceof、typeof、===、!== 等能够让类型更准确的判断。
类型守卫相当于自动的类型断言,当类型守卫搞不定的时候,就手动用类型断言 as 来缩小类型。
我们梳理了实现类型守卫的思路,就是遇到条件语句 IfStatement、SwitchStatement 的时候,对 test 部分做判断,如果包含 in、instanceof、typeof 等,做相应的类型处理,之后再进行类型检查。
猜你喜欢
- 页面设置方法与文章布局技巧(提高文章可读性的关键步骤和注意事项)
- 使用U盘启动PE一键装机教程XP系统安装指南(简单易懂的操作步骤,让你轻松完成XP系统的安装)
- 掌握筹码分布图,成为投资高手!(从入门到精通,轻松掌握筹码分布图技巧)
- vivo手机截屏技巧大揭秘!(最快速的方法让你轻松截屏,不再错过任何重要时刻!)
- Pixelbook教程(探索Pixelbook的功能与技巧,体验极致的电脑操作体验)
- 华硕电脑U盘装系统教程(解决问题快速高效,华硕电脑U盘装系统必备技巧)
- 解决鼠标可以移动但点击无效的问题(探索有效的鼠标点击修复方法)
- 微星GL72拆机教程(轻松拆解微星GL72笔记本电脑,发现其内部奥秘)
- 硬盘Ghost分区教程(使用Ghost软件实现硬盘分区备份与还原,保障数据安全与稳定性)