当前位置:首页 > 科技  > 软件

TypeScript 中的类型与接口

来源: 责编: 时间:2024-05-16 09:10:36 87观看
导读在 TypeScript 中,定义类型有两种方式:“类型”和“接口”。人们经常想知道该使用哪一种,答案并非适用于所有情况。有时一种更好,但在许多情况下,两者可以互换使用。我们来详细了解一下类型和接口的不同点和相似点。类型和

在 TypeScript 中,定义类型有两种方式:“类型”和“接口”。I2n28资讯网——每日最新资讯28at.com

人们经常想知道该使用哪一种,答案并非适用于所有情况。有时一种更好,但在许多情况下,两者可以互换使用。I2n28资讯网——每日最新资讯28at.com

我们来详细了解一下类型和接口的不同点和相似点。I2n28资讯网——每日最新资讯28at.com

类型和类型别名

在 TypeScript 中,我们有一种叫做“类型”的东西,它帮助我们描述我们正在处理的数据类型。这就像为我们的信息提供一个蓝图。I2n28资讯网——每日最新资讯28at.com

基本类型包括字符串、布尔值、数字、数组、元组和枚举。I2n28资讯网——每日最新资讯28at.com

但是,还有更多!我们还有“类型别名”。可以把它们想象成类型的昵称。我们不是在创建新类型;我们只是给它们起了更友好的名称。这使我们的代码更容易阅读和理解。I2n28资讯网——每日最新资讯28at.com

例如,我们可以为数字创建一个叫做“我的数字”的类型别名,所以我们可以不用写“数字”,只需要说“我的数字”。I2n28资讯网——每日最新资讯28at.com

我们还可以为用户数据创建一个类型别名,描述一个用户的数据应该是什么样子。I2n28资讯网——每日最新资讯28at.com

当人们讨论“类型与接口”时,他们实际上是在讨论“类型别名与接口”。这就像给同一组事物起了不同的名称。I2n28资讯网——每日最新资讯28at.com

TypeScript 中的接口

在 TypeScript 中,可以将接口视为一个对象必须遵循的规则或要求集合。这就像一份合约,说:“嘿,如果你想成为‘客户’,你必须有‘名称’和‘地址’。”I2n28资讯网——每日最新资讯28at.com

现在,还有另一种表达这些规则的方法。你可以使用所谓的“类型注解”。这有点像说,“这里是‘客户’应该长什么样子”,然后列出‘名称’和‘地址’属性及其类型,就像你在接口中所做的那样。I2n28资讯网——每日最新资讯28at.com

所以,无论你使用接口还是类型注解,你本质上都在定义同样的期望集合,对于‘客户’应该是什么样子。这就像给同一组指令起了两个不同的名字。I2n28资讯网——每日最新资讯28at.com

类型和接口的区别

类型和接口用于定义自定义数据结构和形状,但它们在行为和使用上有一些差异。I2n28资讯网——每日最新资讯28at.com

原始类型

使用类型:I2n28资讯网——每日最新资讯28at.com

type MyNumber = number;

在这种情况下,我们创建了一个类型别名 MyNumber,它是 number 原始类型的别名。I2n28资讯网——每日最新资讯28at.com

使用接口:I2n28资讯网——每日最新资讯28at.com

你不能使用接口直接定义像 number 这样的原始类型。它们在 TypeScript 中是预定义的。I2n28资讯网——每日最新资讯28at.com

联合类型

使用类型:I2n28资讯网——每日最新资讯28at.com

type MyUnionType = number | string;

在这里,我们定义了一个类型 MyUnionType,它可以包含 number 或 string 的值。I2n28资讯网——每日最新资讯28at.com

使用接口:I2n28资讯网——每日最新资讯28at.com

接口通常不用于直接表示联合类型。你应该使用类型别名来表示这种用途。I2n28资讯网——每日最新资讯28at.com

函数类型

使用类型:I2n28资讯网——每日最新资讯28at.com

type MyFunctionType = (arg1: number, arg2: string) => boolean;

这定义了一个类型 MyFunctionType,用于一个函数,该函数接受两个参数,一个数字和一个字符串,并返回一个布尔值。I2n28资讯网——每日最新资讯28at.com

使用接口:I2n28资讯网——每日最新资讯28at.com

interface MyFunctionInterface {  (arg1: number, arg2: string): boolean;}

这个接口 MyFunctionInterface 表示相同的函数类型。I2n28资讯网——每日最新资讯28at.com

声明合并

使用接口:I2n28资讯网——每日最新资讯28at.com

interface Person {  name: string;}interface Person {  age: number;}

TypeScript 将自动将这两个 Person 接口合并为一个,包含 name 和 age 的属性。I2n28资讯网——每日最新资讯28at.com

使用类型:I2n28资讯网——每日最新资讯28at.com

类型别名不支持声明合并。如果你多次定义相同的类型别名,将导致错误。I2n28资讯网——每日最新资讯28at.com

扩展 vs. 交叉

使用扩展:I2n28资讯网——每日最新资讯28at.com

interface A { propA: number; }interface B extends A { propB: string; }

接口 B 扩展了接口 A,继承了 propA 属性并添加了新的属性 propB。I2n28资讯网——每日最新资讯28at.com

使用交叉:I2n28资讯网——每日最新资讯28at.com

type AB = A & { propB: string; }

在这里,我们使用交叉来组合 A 的属性和新属性 propB,以创建类型 AB。I2n28资讯网——每日最新资讯28at.com

扩展时处理冲突

TypeScript 要求扩展时具有相同名称的属性的类型匹配:I2n28资讯网——每日最新资讯28at.com

interface A { commonProp: number; }interface B { commonProp: string; }interface AB extends A, B { }// 错误: A 和 B 中的 'commonProp' 属性必须具有相同的类型

typescript要解决冲突,你需要确保类型匹配或使用函数的方法重载。I2n28资讯网——每日最新资讯28at.com

处理元组类型

使用类型:I2n28资讯网——每日最新资讯28at.com

type MyTupleType = [number, string];const tuple: MyTupleType = [42, "hello"];

在这里,我们使用 type 定义了一个元组类型,然后我们可以创建该元组类型的变量。I2n28资讯网——每日最新资讯28at.com

使用接口:I2n28资讯网——每日最新资讯28at.com

interface MyTupleInterface {  0: number;  1: string;}const tuple: MyTupleInterface = [42, "hello"];

你也可以使用接口定义元组类型,使用方式保持不变。I2n28资讯网——每日最新资讯28at.com

何时使用类型 vs. 接口

当你需要组合或修改现有结构时,使用接口。如果你在处理库或创建新的库,接口是你的首选。I2n28资讯网——每日最新资讯28at.com

它们允许你合并或扩展声明,使得与现有代码一起工作更加容易。当你以面向对象编程的方式思考时,接口也更易读。I2n28资讯网——每日最新资讯28at.com

当你需要更强大的功能时,选择类型。TypeScript 的类型系统提供了诸如条件类型、泛型、类型保护等高级工具。I2n28资讯网——每日最新资讯28at.com

这些功能为你提供了更多控制你的类型的方式,帮助你创建健壮、强类型的应用程序。接口无法提供这些能力。I2n28资讯网——每日最新资讯28at.com

你通常可以根据个人喜好使用类型或接口。然而,在以下情况下使用类型别名:I2n28资讯网——每日最新资讯28at.com

  • • 当你想为基本数据类型(如‘字符串’或‘数字’)创建一个新名称时。
  • • 当定义更复杂的类型如联合、元组或函数时。
  • • 当重载函数时。
  • • 当使用高级功能如映射类型、条件类型或类型保护时。

类型通常更灵活和表达性强。它们提供了一系列接口无法匹敌的高级功能,而 TypeScript 持续扩展其能力。I2n28资讯网——每日最新资讯28at.com

我们使用类型别名自动生成一个对象类型的 getter 方法,这是你无法通过接口做到的:I2n28资讯网——每日最新资讯28at.com

type Client = {    name: string;    address: string;}type Getters<T> = {    [K in keyof T as `get${Capitalize<string & K>}`]: () => T[K];};type clientType = Getters<Client>;// 结果是: // {//     getName: () => string;//     getAddress: () => string;// }

通过使用映射类型、模板文字和‘keyof’操作符,我们创建了一个类型,它可以为任何对象类型自动生成 getter 方法。I2n28资讯网——每日最新资讯28at.com

此外,许多开发者更喜欢使用类型,因为它们与函数式编程范式很契合。I2n28资讯网——每日最新资讯28at.com

TypeScript 中类型表达式的丰富性使得在保持类型安全的同时,更容易与函数式概念如组合和不变性一起工作。I2n28资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-88396-0.htmlTypeScript 中的类型与接口

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 聊聊主流的Kafka监控框架

下一篇: React 全新编译器太好用了!

标签:
  • 热门焦点
  • 一加Ace2 Pro真机揭晓 钛空灰配色质感拉满

    一加Ace2 Pro真机揭晓 钛空灰配色质感拉满

    终于,在经过了几波预热之后,一加Ace2 Pro的外观真机图在网上出现了。还是博主数码闲聊站曝光的,这次的外观设计还是延续了一加11的方案,只是细节上有了调整,例如新加入了钛空灰
  • 5月iOS设备性能榜:M1 M2依旧是榜单前五

    5月iOS设备性能榜:M1 M2依旧是榜单前五

    和上个月一样,没有新品发布的iOS设备性能榜的上榜设备并没有什么更替,仅仅只有跑分变化而产生的排名变动,刚刚开始的苹果WWDC2023,推出的产品也依旧是新款Mac Pro、新款Mac Stu
  • Automa-通过连接块来自动化你的浏览器

    Automa-通过连接块来自动化你的浏览器

    1、前言通过浏览器插件可实现自动化脚本的录制与编写,具有代表性的工具就是:Selenium IDE、Katalon Recorder,对于简单的业务来说可快速实现自动化的上手工作。Selenium IDEKat
  • 分享六款相见恨晚的PPT模版网站, 祝你做出精美的PPT!

    分享六款相见恨晚的PPT模版网站, 祝你做出精美的PPT!

    1、OfficePLUSOfficePLUS网站旨在为全球Office用户提供丰富的高品质原创PPT模板、实用文档、数据图表及个性化定制服务。优点:OfficePLUS是微软官方网站,囊括PPT模板、Word模
  • 谷歌KDD'23工作:如何提升推荐系统Ranking模型训练稳定性

    谷歌KDD'23工作:如何提升推荐系统Ranking模型训练稳定性

    谷歌在KDD 2023发表了一篇工作,探索了推荐系统ranking模型的训练稳定性问题,分析了造成训练稳定性存在问题的潜在原因,以及现有的一些提升模型稳定性方法的不足,并提出了一种新
  • 这款新兴工具平台,让你的电脑效率翻倍

    这款新兴工具平台,让你的电脑效率翻倍

    随着信息技术的发展,我们获取信息的渠道越来越多,但是处理信息的效率却成为一个瓶颈。于是各种工具应运而生,都在争相解决我们的工作效率问题。今天我要给大家介绍一款效率
  • 阿里大调整

    阿里大调整

    来源:产品刘有媒体报道称,近期淘宝天猫集团启动了近年来最大的人力制度改革,涉及员工绩效、层级体系等多个核心事项,目前已形成一个初步的&ldquo;征求意见版&rdquo;:1、取消P序列
  • 联想的ThinkBook Plus下一版曝光,键盘旁边塞个平板

    联想的ThinkBook Plus下一版曝光,键盘旁边塞个平板

    ThinkBook Plus 是联想的一个特殊笔记本类别,它在封面放入了一块墨水屏,也给人留下了较为深刻的印象。据有人爆料,联想的下一款 ThinkBook Plus 可能更特殊,它
  • Meta盲目扩张致超万人被裁,重金押注元宇宙而前景未明

    Meta盲目扩张致超万人被裁,重金押注元宇宙而前景未明

    图片来源:图虫创意日前,Meta创始人兼CEO 马克&middot;扎克伯发布公开信,宣布Meta计划裁员超11000人,占其员工总数13%。他公开承认了自己的预判失误:&ldquo;不仅
Top
Baidu
map