返回顶部
首页 > 资讯 > 精选 >怎么在TypeScript中保护类型
  • 782
分享到

怎么在TypeScript中保护类型

2023-06-14 22:06:44 782人浏览 薄情痞子
摘要

怎么在typescript中保护类型?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。概述在 TypeScript 中使用联合类型时,往往会碰到这种尴尬的情况:in

怎么在typescript中保护类型?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。

概述

在 TypeScript 中使用联合类型时,往往会碰到这种尴尬的情况:

interface Bird {  // 独有方法    fly();  // 共有方法    layEggs();}interface Fish {  // 独有方法    swim();  // 共有方法    layEggs();}function getSmallPet(): Fish | Bird {    // ...}let pet = getSmallPet();pet.layEggs(); // 正常pet.swim();    // ts 报错

如上所示,getSmallPet函数中,既可以返回 Fish 类型的对象,又可以返回 Bird 类型的对象。由于返回的对象类型不确定,所以使用联合类型对象共有的方法时,一切正常,但是使用联合类型对象各自独有的方法时,ts 会报错。

那么如何解决这个问题呢?最粗暴的方法当然是将联合类型转换为 any,不过这种方法不值得提倡,毕竟我们写的是 TypeScript 而不是 AnyScript。

此时,我们使用今天的主角——类型保护,闪亮登场,它可以完美的解决这个问题。

孔乙己说过,茴香豆有四种写法,同理,实现类型保护,也有四种写法。

类型断言

类型断言是最常用的一种类型保护方法,即直接指定类型。由于,TypeScript 中识别的类型大多是靠 TypeScript 的自动类型推算算出来的,所以会出现上面所说的那种问题,即 TypeScript 不知道具体对象类型是什么,所以不确定有没有联合类型各自独有的方法。

当使用类型断言直接指定类型时,相当于你让 TypeScript 开启了上帝模式,可以直接知道具体类型是联合类型中的那个,此时再使用对象的独有方法就符合 TypeScript 的推断了。

interface Bird {  // 独有方法  fly();  // 共有方法  layEggs();}interface Fish {  // 独有方法  swim();  // 共有方法  layEggs();}function getSmallPet(): Fish | Bird {  // ...}let pet = getSmallPet();pet.layEggs(); // 正常// 通过鸭子类型来进行判断if ((pet as Bird).fly) {  // 类型断言  (pet as Bird).fly()} else {  // 类型断言  (pet as Fish).swim()}

如果嫌弃通过 as 来进行类型断言不够上流,还可以使用类泛型的写法,即:

let pet = getSmallPet();pet.layEggs(); // 正常// 通过鸭子类型来进行判断if ((<Bird>pet).fly) {  (<Bird>pet).fly()} else {  (<Fish>pet).swim()}

tips:友情提示,虽然使用类泛型写法进行类型断言看起来高端一些,但是由于在 tsx 中语法存在歧义,所以为了统一起见,推荐使用 as 的方法进行类型断言。

in语法

js中,我们经常使用 in 语法来判断指定的属性是否在指定的对象或其原型链中。

同理,在 TypeScript 中,我们可以通过这种方法确认对象类型。

interface Bird {  // 独有方法  fly();  // 共有方法  layEggs();}interface Fish {  // 独有方法  swim();  // 共有方法  layEggs();}function getSmallPet(): Fish | Bird {  // ...}let pet = getSmallPet();pet.layEggs(); // 正常// 使用 in 语法进行类型保护if ('fly' in pet) {  pet.fly()} else {  pet.swim()}

原理同类型断言一样,都是引导 TypeScript 的类型推断,确定对象类型。

instanceof 语法

当联合类型中使用的是 class 而不是 interface 时,instanceof 语法就派上用场了,通过 instanceof 语法可以区分不同的 class 类型。

class Bird {  // 独有方法  fly() {};  // 共有方法  layEggs() {};}class Fish {  // 独有方法  swim() {};  // 共有方法  layEggs() {};}function getSmallPet(): Fish | Bird {  // ...}let pet = getSmallPet();pet.layEggs(); // 正常// 使用 in 语法进行if (pet instanceof Bird) {  pet.fly()} else {  pet.swim()}

typeof 语法

typeof 语法不同于 in 语法以及 instanceof 语法,in 语法以及 instanceof 语法都是用来引导类型推断进行不同对象类型推断,而 typeof 语法常用于基本类型的推断(或者是联合使用基本类型和对象类型)。

简而言之,当使用 typeof 能够区分联合类型中的不同类型时,即可使用它。

function getSmallPet(): number | string {  // ...}let pet = getSmallPet();if (typeof pet === 'number') {  pet++} else {  pet = Number(pet) + 1}

看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注编程网精选频道,感谢您对编程网的支持。

--结束END--

本文标题: 怎么在TypeScript中保护类型

本文链接: https://lsjlt.com/news/275430.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • 怎么在TypeScript中保护类型
    怎么在TypeScript中保护类型?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。概述在 TypeScript 中使用联合类型时,往往会碰到这种尴尬的情况:in...
    99+
    2023-06-14
  • 详解TypeScript中的类型保护
    目录概述类型断言in语法instanceof 语法typeof 语法总结概述 在 TypeScript 中使用联合类型时,往往会碰到这种尴尬的情况: interface Bird...
    99+
    2024-04-02
  • TypeScript联合类型,交叉类型和类型保护怎么理解
    本篇内容介绍了“TypeScript联合类型,交叉类型和类型保护怎么理解”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.联合类型所谓的联合...
    99+
    2023-06-22
  • TypeScript联合类型,交叉类型和类型保护
    目录1.联合类型2.交叉类型3.类型保护3.1自定义类型保护3.2typeof 类型保护3.3instanceof类型保护1.联合类型 所谓的联合类型就是定义一些类型,定义的变量只...
    99+
    2024-04-02
  • Typescript中number类型怎么用
    这篇文章主要为大家展示了“Typescript中number类型怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Typescript中number类型怎么用...
    99+
    2024-04-02
  • Typescript中boolean类型怎么用
    这篇文章主要为大家展示了“Typescript中boolean类型怎么用”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Typescript中boolean类型怎...
    99+
    2024-04-02
  • Typescript中array类型怎么用
    小编给大家分享一下Typescript中array类型怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!array数组类型,跟...
    99+
    2024-04-02
  • Typescript中string类型怎么用
    这篇文章给大家分享的是有关Typescript中string类型怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。string字符串类型,和javascript一样,可以使用双...
    99+
    2024-04-02
  • Typescript中any类型怎么用
    小编给大家分享一下Typescript中any类型怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!any可以指定任何类型的值...
    99+
    2024-04-02
  • Typescript中enum类型怎么用
    小编给大家分享一下Typescript中enum类型怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!enumenum类型是对...
    99+
    2024-04-02
  • Typescript中tuple类型怎么用
    小编给大家分享一下Typescript中tuple类型怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!tuple元组类型,允...
    99+
    2024-04-02
  • Typescript中object类型怎么用
    小编给大家分享一下Typescript中object类型怎么用,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!object对象类型...
    99+
    2024-04-02
  • Typescript中never类型怎么用
    这篇文章将为大家详细讲解有关Typescript中never类型怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。nevernever是其他类型(包括null和unde...
    99+
    2024-04-02
  • TypeScript中的递归类型是什么
    这篇文章主要讲解了“TypeScript中的递归类型是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“TypeScript中的递归类型是什么”吧!什么是递归类型?递归类型是指一个类型在定义...
    99+
    2023-07-05
  • 怎么在TypeScript中实现接口的类
    这篇文章主要介绍“怎么在TypeScript中实现接口的类”,在日常操作中,相信很多人在怎么在TypeScript中实现接口的类问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么在TypeScript中实现接...
    99+
    2023-07-05
  • TypeScript中的类型断言语法怎么使用
    这篇文章主要介绍“TypeScript中的类型断言语法怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“TypeScript中的类型断言语法怎么使用”文章能帮助大家解决问题。Typescript...
    99+
    2023-07-02
  • 怎么在Redis中设置密码保护
    怎么在Redis中设置密码保护?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Redis安装好了之后,默认是没有密码保护的,为了安全要设置密...
    99+
    2024-04-02
  • TypeScript中泛型怎么用
    这篇文章将为大家详细讲解有关TypeScript中泛型怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。泛型避免代码重复中,创建可重用的类型,是我们编写简洁代码重要的一...
    99+
    2024-04-02
  • TypeScript条件类型与内置条件类型怎么使用
    这篇文章主要讲解了“TypeScript条件类型与内置条件类型怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“TypeScript条件类型与内置条件类型怎么使用”吧!一、TS中条件类型...
    99+
    2023-07-05
  • typescript类型any不能分配给类型never怎么解决
    这篇“typescript类型any不能分配给类型never怎么解决”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“types...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作