news 2026/4/16 17:14:36

Typescript - 类型守卫(typeof / in / instanceof / 自定义类型保护的类型谓词)通俗易懂详细教程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Typescript - 类型守卫(typeof / in / instanceof / 自定义类型保护的类型谓词)通俗易懂详细教程

前言

类型守卫用于获取变量类型信息,通常使用在条件块语句中。类型守卫是返回布尔值的常规函数,接受一个类型并告诉 TypeScript 是否可以缩小到更具体的类型。类型守卫具有唯一的属性,可以确保测试的值返回的是布尔值类型。

TypeScript 使用了一些内置的 JavaScript 操作符(见下方),这些操作符用于确定一个对象是否包含属性。类型守卫可以让你指导 TypeScript 编译器在特定的上下文中推断出变量的特定类型,确保参数的类型与你指定的一致。

类型守卫非常类似于特征检测,允许您检测值原型和属性。

类型保护是可执行运行时检查的一种表达式,用于确保该类型在一定的范围内。 换句话说,类型保护可以保证一个字符串是一个字符串,尽管它的值也可以是一个数值。类型保护与特性检测并不是完全不同,其主要思想是尝试检测属性、方法或原型,以确定如何处理值。


Typescript 类型守卫主要在类型窄化时使用,其实现类型守卫主要有以下 4 种方式:

  1. typeof(类型判断)
  2. in(属性或方法判断)
  3. instanceof(实例判断)
  4. 自定义类型保护的类型谓词

typeof

该关键字或许您可能在 JavaScript 中见过,甚至使用过。

typeof 只能检查基本数据类型(不能检查复杂数据类型),比如下面这些:

string | number | bigint | boolean | symbol | undefined | object | function

使用方法很简单,如下代码所示:

// 姓名(字符串类型)letuname:string="王佳斌"// 判断其类型console.log(typeofuname)//string

in

它用于检查对象是否具有特定的属性,并使用该属性区分不同的类型。它通常返回一个布尔值,表示该属性是否存在于该对象中。

该操作符用于遍历目标类型的公开属性名,如下代码所示:

// 示例一constobj={name:'王佳斌',age:15}console.log('name属性是否存在于obj对象?','name'inobj)//"name属性是否存在于obj对象?", true// 示例二typeProperty='name'|'age'|'phoneNum';typePropertyObject={[keyinProperty]:string;}

instanceof

它是一个内置类型守卫,可用于检查一个值是否是给定构造函数或类的实例。

有了这个类型守卫,我们可以测试一个对象或值是否派生自一个类,这对于确定实例类型的类型很有用。

instanceof 关键字的基本语法如下:

objectVariable instanceof ClassName;

一个 instanceof 的例子,如下代码所示:

interfaceAccessory{brand:string;}// implements// 实现,一个新的类,从父类或者接口实现所有的属性和方法,同时可以重写属性和方法,包含一些新的功能// 一个类通过关键字implements声明自己使用一个或者多个接口。classNecklaceimplementsAccessory{kind:string;brand:string;constructor(brand:string,kind:string){this.brand=brand;this.kind=kind;}}classbraceletimplementsAccessory{brand:string;year:number;constructor(brand:string,year:number){this.brand=brand;this.year=year;}}constgetRandomAccessory=()=>{returnMath.random()<0.5?newbracelet('cartier',2021):newNecklace('choker','TASAKI');}letAccessory=getRandomAccessory();if(Accessoryinstanceofbracelet){console.log(Accessory.year);}if(AccessoryinstanceofNecklace){console.log(Accessory.brand);}

上面的 getRandomAccessory 函数返回一个 Necklace 或 bracelet 对象,因为它们都实现了 Accessory 接口。

Necklace 和 bracelet 的构造函数签名是不同的,用 instanceof 比较两个构造函数签名可以有效地确定类型。

自定义类型保护的类型谓词

这种自定义的方式更加灵活,如下代码所示:

// 验证是否是number类型functionisNumber(x:any):xisnumber{returntypeofx==="number";}// 验证是否是string类型functionisString(x:any):xisstring{returntypeofx==="string";}

调用函数传入参数(any 任意类型),如果类型正确则返回 true,反之 false。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 14:01:08

python_django基于微信小程序的校园店铺商城电子商务系统

文章目录基于微信小程序的校园店铺商城电子商务系统摘要系统设计与实现的思路主要技术与实现手段源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;基于微信小程序的校园店铺商城电子商务系统摘要 系统概述 该系统为校园场景设计&#xff0…

作者头像 李华
网站建设 2026/4/15 20:24:19

C++STL链表实现全解析

C STL list 模拟实现&#xff1a;从底层链表到容器封装 在C标准模板库&#xff08;STL&#xff09;中&#xff0c;list是一个基于双向链表实现的序列容器&#xff0c;它提供高效的插入和删除操作&#xff0c;时间复杂度通常为$O(1)$。下面我将从底层链表结构开始&#xff0c;逐…

作者头像 李华
网站建设 2026/4/16 16:12:22

vue+uniapp+Python微信小程序社区老年人活动志愿者服务系统

文章目录系统概述技术架构核心功能创新点应用价值系统设计与实现的思路主要技术与实现手段源码lw获取/同行可拿货,招校园代理 &#xff1a;文章底部获取博主联系方式&#xff01;系统概述 基于Vue.js和Uniapp框架的前端开发&#xff0c;结合Python后端技术&#xff0c;构建微信…

作者头像 李华
网站建设 2026/4/16 15:33:29

AI重塑软件工程:从需求到部署的全链路智能化革命

《AI赋能软件工程工具链全景图》深入剖析了AI如何重塑软件开发全流程&#xff1a;从智能需求解析、代码生成、智能测试到自动化部署&#xff0c;核心依托大模型RAG技术。这种端到端智能化革命使交付效率提升40%&#xff0c;缺陷率下降60%&#xff0c;开发者正从"写代码&qu…

作者头像 李华
网站建设 2026/4/16 15:55:20

DeepSeek V4全网猜测汇总:四大焦点浮出水面

AI圈近期的热度&#xff0c;几乎全被DeepSeek V4的相关猜测承包了。恰逢DeepSeek-R1发布一周年&#xff0c;官方GitHub代码库中突然曝光的“MODEL1”标识&#xff0c;瞬间点燃全网讨论热情。开发者拆解代码、外媒爆料动态、行业人士解读技术&#xff0c;各类声音层出不穷。今天…

作者头像 李华
网站建设 2026/4/15 19:38:32

后端开发转行大模型应用开发,后端开发者的新战场:大模型应用开发,这份转型指南带你抢占AI风口!

前言 在人工智能&#xff08;AI&#xff09;迅速发展的背景下&#xff0c;从传统的编程领域如Java程序员转向大模型开发是一个既充满挑战也充满机遇的过程。对于 Java 程序员来说&#xff0c;这也是一个实现职业转型、提升薪资待遇的绝佳机遇。 前排提示&#xff0c;文末有大…

作者头像 李华