当前位置: 首页 > news >正文

cnd设计网站官网关键词你们懂的

cnd设计网站官网,关键词你们懂的,阿里巴巴网站威海哪里做,2023年山西疫情TypeScript 中的type与interface 对于 TypeScript,有两种定义类型的方法:type与interface。 人们常常想知道该使用哪一种,而答案并不是一刀切的。这确实取决于具体情况。有时,其中一种比另一种更好,但在许多情况下&a…

TypeScript 中的type与interface

对于 TypeScript,有两种定义类型的方法:typeinterface

人们常常想知道该使用哪一种,而答案并不是一刀切的。这确实取决于具体情况。有时,其中一种比另一种更好,但在许多情况下,我们可以互换使用它们。

那么,让我们来分析一下typeinterface有其区别和相似之处。

在本文中,我们将深入探讨这些区别,并总结什么时候使用它们。

type

js中有一些基本类型,如字符串、布尔值、数字、数组、元组和枚举。通过 TypeScripttype我们定义更多的类型,我们不是在创造新类型,只是给他们起了更友好的名字。这使得我们的代码更容易阅读和理解。

type MyNumber = number;
type User = {id: number;name: string;email: string;
}

例如,我们可以为number创建一个名为MyNumber的类型别名,因此我们可以直接说MyNumber,而不是写number

我们还可以为User 创建一个类型别名,它描述了用户的数据应该是什么样子。

当人们谈论type时,他们实际上是在谈论类型别名。这就像给同一组事物赋予不同的名称一样。

interface

TypeScript 中,将interface视为对象必须遵循的一组规则或要求。

interface Client { name: string; address: string;
}

现在,有另一种方式来表达这些规则。我们可以使用所谓的“类型注释”来更好的解释Client所包含的属性。

因此,无论我们使用type还是interface,我们本质上都是在为Client定义相同的期望集。这就像为同一组指令赋予两个不同的名称。

type与interface的差异

typeinterface都是用于定义自定义数据结构和形状,但它们的行为和用法有一些差异。

原始类型

使用type
type MyNumber = number;
使用interface

我们不能像直接使用interface定义原始类型number。原始类型都是在 TypeScript 中预定义的。

联合类型

使用type
type MyUnionType = number | string;

在这里,我们定义了一个MyUnionType的类型,它可以保存numberstring类型的值。

使用interface

interface通常不用于直接表示联合类型。

函数类型

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

这定义了一个MyFunctionType函数的类型,该函数接受两个参数(一个数字和一个字符串)并返回一个布尔值。

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

声明合并

使用type

类型别名不支持声明合并。如果多次定义相同的类型别名,将会导致错误。

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

TypeScript 会自动将这两个Person接口合并为一个,并且具有nameage的属性。

扩展

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

接口B扩展接口A,继承propA属性并添加新属性propB

使用&来扩展
type AB = A & { propB: string; }

在这里,我们使用交集将类型A与新属性propB组合起来创建类型AB。

处理扩展时的冲突

TypeScript 强制扩展时具有相同名称的属性类型匹配:

interface A { commonProp: number; }
interface B { commonProp: string; }
interface AB extends A, B { }
// Error: Property 'commonProp' must have the same type in A and B

要解决冲突,我们需要确保类型匹配或使用函数的方法重载。

使用元组类型

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

在这里,我们使用type定义一个元组类型,然后我们可以创建该元组类型的变量。

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

我们还可以使用接口定义元组类型,并且用法保持不变。

何时使用type与interface

当需要组合或修改现有结构时,请使用interface。如果我们正在使用库或创建新库,那么interface是我们的首选。

它们允许我们合并或扩展声明,从而更轻松地使用现有代码。当我们考虑面向对象编程时,interface也更具可读性。

当我们需要更强大的功能时,可以选择typeTypeScript 的类型系统提供了高级工具,例如条件类型、泛型、类型防护等等。

这些功能使我们可以更好地控制类型,帮助我们创建健壮的强类型应用程序。interface无法提供这些功能。

我们通常可以使用typeinterface,具体取决于我们的个人喜好。但是,在以下情况下请使用type

  • 当我们想要为基本数据类型创建新名称(例如“字符串”或“数字”)时。
  • 定义更复杂的类型(例如联合、元组或函数)时。
  • 重载函数时。
  • 使用映射类型、条件类型或类型防护等高级功能时。

type通常更灵活且更具表现力。它们提供了interface无法比拟的更广泛的高级功能,并且 TypeScript 不断扩展其功能。

我们使用类型别名来自动生成对象类型的 getter 方法,这是interface无法做到的:

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 方法的类型。

此外,许多开发人员更喜欢使用type,因为它们与函数式编程范例非常一致。

TypeScript 中类型表达式的丰富性使我们可以更轻松地使用组合和不变性等函数概念,同时保持代码中的类型安全。

http://www.khdw.cn/news/6600.html

相关文章:

  • WordPress修改用户IP插件网站seo 优化
  • 备案网站域名被抢注湖北seo
  • 郑州网站seo优化企业营销推广方案
  • 学校网站设计及代码推广公司有哪些
  • 品牌平价网站建设百度推广效果怎样
  • 大型旅行社自建网站白山网络推广
  • 广东网站建设定制武汉网络营销公司排名
  • 怎么做进入网站js特效搜索网
  • 海尔网站建设投入域名查询
  • 2023年石家庄疫情怎么样了seo页面代码优化
  • 济宁住房和城乡建设厅网站免费推广方式有哪些
  • 杭州网站公司企业网站有哪些平台
  • 广州网站设计首选柚米江苏seo
  • 网站怎么做链接跳转seo公司培训课程
  • 网站开发的五个阶段网站制作培训
  • 合肥外贸网站建设营销型企业网站的功能
  • 商城 静态网站模板海外推广渠道
  • 如果做好招聘网站建设广西seo快速排名
  • 广州天河建站公司网站建设一般多少钱
  • 交易平台网站制作关键词挖掘工具爱站网
  • 生成前端页面的网站公司网站模板设计
  • 网站的分辨率是多少像素现在最好的免费的建站平台
  • 如何利用ps做网站互联网营销是做什么的
  • 眉县住房和建设委员会网站如何做一个自己的网站呢
  • 绥化网站建设常熟seo网站优化软件
  • 苏州建站模板系统百度网站制作
  • 做网站公司官网泉州百度开户
  • 广州手机网站建设营销网站建设门户
  • a0000网站建设seo网站
  • 做侵权视频网站网站关键词排名如何提升