首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

TypeScript 对象类型-接口

一、什么是接口 在 TypeScript ,我们使用接口(Interfaces)来定义对象类型 接口是一系列抽象方法声明,是一些方法特征集合,第三方可以通过这组抽象方法调用,让具体类执行具体方法...TypeScript 接口除了可用于对类一部分行为进行抽象以外,还可用于对「对象形状(Shape)」进行描述 举个例子: interface Person { name: string;...number; } let faker: Person = { name: 'Faker', age: 25, gender: 'male' }; 四、只读属性 有时候我们希望对象一些字段只能在创建时候被赋值...上例,使用 readonly 定义属性 id 初始化后又被赋值,所以报错 注意,只读约束存在于第一次给对象赋值时候,而非第一次给只读属性赋值时候: interface Person {...上例,报错信息有两处: 1、在对 faker 进行赋值时候,没有给 id 赋值 2、在给 faker.id 赋值时候,由于它是只读属性,所以报错了 五、联合类型和接口 以下实例演示了如何在接口中使用联合类型

3.3K10
您找到你想要的搜索结果了吗?
是的
没有找到

TypeScript 基础类型:原始类型对象类型、数组类型、元组类型、枚举类型和联合类型

TypeScript 强大类型系统使得开发者能够更轻松地编写可维护、可扩展代码。本文将详细介绍 TypeScript 基础类型,包括原始类型对象类型、数组类型、元组类型、枚举类型和联合类型。...原始类型TypeScript ,有以下几种原始类型:数字类型数字类型用于表示整数或浮点数。可以使用 number 关键字来声明数字变量。...可以使用 object 关键字来声明对象类型对象类型对象类型用于表示一个对象,其中包含多个键值对。可以使用 {} 或者 object 关键字来声明对象类型对象类型可以指定属性名和属性值类型。...类型推断和类型断言TypeScript 具有强大类型推断能力,它可以根据上下文自动推断变量类型。例如,如果我们在定义变量时直接赋值,TypeScript 可以推断出变量类型。...总结本文详细介绍了 TypeScript 基础类型,包括原始类型对象类型、数组类型、元组类型、枚举类型和联合类型等方面。

31230

TypeScript类型断言

本文是关于 TypeScript type assertions ,它与其他语言中类型强制转换有相似之处,并通过 as 运算符执行。...在 B 行,我们看到此类型不允许访问任何属性。 在 C 行,我们用类型断言(运算符 as)告诉 TypeScript data 是一个Array。现在就可以访问属性 .length 了。...类型断言是不得已方法,应尽可能避免。他们(暂时)删除了静态类型系统为我们提供安全网。 注意,在 A 行,我们还覆盖了 TypeScript 静态类型,不过是通过类型注释完成。...类型断言替代语法 TypeScript 对于类型断言有另一种“尖括号”语法: 1>data 该语法已经过时,并且与 React JSX 代码(在 .tsx 文件)不兼容。...示例:声明一个接口 为了访问任意对象 obj 属性 .name,我们暂时将 obj 静态类型更改为 Named(A行和B行)。

3.7K40

TypeScript 数组类型定义

TypeScript 声明和初始化数组也很简单,和声明数字类型和字符串类型变量也差不多,只不过在指定数组类型时要在类型后面加上一个括号 [] 语法格式 const array_name: dataype...array: Array = ['孟浩然', 99]; 除了使用括号 [] 方法来声明数组,你还可以使用 数组泛型 来定义数组 语法格式 const array_name..., val2, val3],[v1, v2, v3]]; // 等同于 const array_name: datatype[][] = [[val1, val2, val3]]; 多维数组类型 TypeScript...等同于 const test: string[][] = [['狮子头', '清蒸鲈鱼', '鲜椒牛蛙'], ['北京烤鸭'], ['地锅鸡', '饿了']]; 声明一个二维数组 注意: 以下示例类型在数组...个 建议: 在定义数组类型时候使用数组泛型定义,这样显得更直观一点 Tuple 元组类型(元组类型允许表示一个已知元素数量和类型数组)

5.3K40

实现TypeScript互斥类型

对象多属性同类型定义 有一个对象它包含5个可选属性a、b、c、d、e,他们类型都为string,大多数人定义方式应该如下所示: type obj = { a?:string; b?...: string }; never类型TypeScript它有一个特殊类型never,它是所有类型类型,无法再进行细分,也就意味着除了其本身没有类型可以再分配给它。... // "a" | "d" 将对象所有属性转为联合类型 有一个对象它包含2个可选属性name、title,我们想把它转为联合类型name...接下来,我们来梳理下实现思路: 实现一个排除类型,用于从A对象类型剔除B对象类型属性,并将排除后属性类型设为never,得到一个新对象类型。...> & T); 注意:为了类型可复用性,我们使用了泛型,对此不熟悉开发者请移步:TypeScript中文网——泛型 测试用例 我们将文章开头所说问题代入上述实现代码,看一下它能否将其解决,如下所示

3K40

TypeScript 官方手册翻译计划【五】:对象类型

项目地址:TypeScript-Doc-Zh,如果对你有帮助,可以点一个 star ~ 本章节官方文档地址:Object Types 对象类型 在 JavaScript ,最基础分组和传递数据方式就是使用对象...在 TypeScript ,我们则通过对象类型来表示。...属性修饰符 对象类型每个属性都可以指定一些东西:属性类型、属性是否可选,属性是否可写。 可选属性 大多数时候,我们会发现自己处理对象可能有一个属性集。...在使用 TypeScript 进行开发过程,它可以有效地表明一个对象应该如何被使用。...TypeScript 还提供了另一种称为“交叉类型结构,可以用来结合已经存在对象类型

1.7K30

TypeScript 顶级类型:any 和 unknown

翻译:疯狂技术宅 作者:Dr. Axel Rauschmayer 正文共:2525 字 预计阅读时间:10 分钟 ? 在 TypeScript,any 和 unknown 是包含所有值类型。...在本文中,我们将会研究它们是怎样工作。 ---- TypeScript 两种顶级类型 any 和 unknown 在 TypeScript 是所谓“顶部类型”。...以下文字引用自 维基百科 (https://en.wikipedia.org/wiki/Top_type): top type […]是 通用(universal) 类型,有时也称为 通用超类型,因为在任何给定类型系统...const b: boolean = value; const c: object = value; } 使用 any,我们将会失去通常由 TypeScript 静态类型系统所给予所有保护...): any; 在 unknown 类型出现之前,JSON.parse() 就已经被添加到了 TypeScript

2.4K20

TypeScript高级类型工具类型及关键字

本文主要帮助理解 TypeScript 高级类型及工具类型。在实际使用 TypeScript 开发过程,得益于这些高级类型于工具类型,我们可以更方便构建出我们需要类型。...比如说:我们在后台登陆信息认证构建了一个用户,它是 LoginUser 类型, 它包含了:“name 用户名”、“email 邮箱”、“roles:角色”等多个信息,其中 name 可能不是必选项。...属性 object // 第二个参数设置为第一个参数这个对象一个属性 // 第三个参数设置为第二个参数属性值 const addAttr = <T extends {name: string},...T, K 相同类型构造一个新类型 // type Extract = T extends U ?...T 处理过程某个部分抽离出来当做类型变量 type Unpacked = T extends (infer U)[] ?

2.1K30

TypeScript自定义类型对象属性必选、对象属性可选

前沿TS实现对象属性必选、对象属性在开发过程十分常见,前端在传参数时,有些参数比必传,有些是选传,我们可以定一个多个对象来实现传参,但是这让代码变得冗余。我们可以通过TS定义数据类型来实现。...一、把对象类型指定key变成可选1.实现用到ts基础keyof T生成新类型,也就是联合字面量类型,组成字面量类型是T属性名称所组成。...info对象中所有属性对象类型。...思路如下:首先需要把可选属性去除,得到一个不包括可选属性对象类型将剩余属性组成对象类型与可选属性组成对象类型交叉,得到最终结果使用TSExclude工具类型,从联合类型中去除指定属性,最终得到联合类型...ExcludeK为'id' | 'name'keyof T为'name'| 'id'| 'age'| 'class'接着使用Pick工具类型,从对象类型(info)抽取出指定类型键值

71520

TypeScript函数类型

对其进行约束,需要把输入和输出都考虑到,其中函数声明类型定义较简单: function sum(x:number,y:number):number{ return x+y; }; //...{ return x+y; }; 注意不要混淆了 TypeScript => 和 ES6 =>。...在 TypeScript 类型定义,=> 用来表示函数定义,左边是输入类型,需要用括号括起来,右边是输出类型。...参数默认值 在 ES6 ,我们允许给函数参数添加默认值,TypeScript 会将添加了默认值参数识别为可选参数: function buildName(firstName:string,lastName...在编辑器代码提示,可以正确看到前两个提示。 注意,TypeScript 会优先从最前面的函数定义开始匹配,所以多个函数定义如果有包含关系,需要优先把精确定义写在前面。

2K30

Typescript ,这些类型工具真好用

你是否曾经用 TypeScript 写代码,然后意识到这个包没有导出我需要类型,例如下面这段代码提示 Content 在 @example 不存在: import {getContent, Content...,TypeScript 为我们提供了许多可以解决这个常见问题类型工具,详细可以参考官方文档给出 utility 类型。...例如,下面我有一个编辑日历事件简单组件,我们在其中维护一个处于状态事件对象,并在发生变化时修改事件标题。 你能发现下面这段代码错误吗?...那你可能突然会问:为什么 TypeScript 没有捕捉到这个错误呢? 从技术上讲,你可以用 useState 改变对象。...Record 创建一个类型来表示具有给定类型任意键对象: const months = Record = { january

18130

TypeScript 始终抽象嵌套类型

TypeScript ,我看到过多次出现这种情况,您有一个复杂对象,该对象可能具有嵌套对象,例如下面的示例:interface ComplexObject { a: string; b: number...不会报错,因为这是有效代码,但随着对象变得越来越大,接口将变得越来越难以阅读。...现在假设我们想要编写一个以该对象作为输入函数,可能会进行一些插值,并且可能会返回该对象对象,例如嵌套属性,您可能会有以下代码:const printObj = (obj: ComplexObject...处理类似上面的复杂对象更好方法是将所有嵌套属性抽象为它们自己接口/类型。.../接口分割为更合理可理解模块,而不是拥有一个可能难以阅读庞大类型/接口。

11600

Typescript 推断函数返回类型

而且,每当 FunkyStuff 发生变化时,我们就必须更新我们代码。好解决方案使用 ReturnType 实用程序类型。...在之前版本,实现相同效果可能有些棘手。总结这个提示只是 TypeScript 提供众多功能冰山一角。...而且,每当 FunkyStuff 发生变化时,我们就必须更新我们代码。好解决方案使用 ReturnType 实用程序类型。...在之前版本,实现相同效果可能有些棘手。总结这个提示只是 TypeScript 提供众多功能冰山一角。...在之前版本,实现相同效果可能有些棘手。总结这个提示只是 TypeScript 提供众多功能冰山一角。我正在参与2023腾讯技术创作特训营第三期有奖征文,组队打卡瓜分大奖!

9010

什么是 TypeScript 4.1 模板字面类型

键值对类型中键重新映射(Key Remapping) 映射类型可以基于任意键创建新对象类型。...在 TypeScript 4.1 ,由于 DOM 类型是自动生成,lib.d.ts 可能具有一组变动 API,例如,从 ES2016 删除 Reflect.enumerate。...在以下使用条件传播示例,如果定义了 file,则将传播 file.owner 属性。否则,不会将任何属性传播到返回对象: function getOwner(file?...否则,结果中一个都不会展示 但是事实证明,这样代价最终会变得非常高昂,而且通常无济于事。在单个对象存在数百个展开对象,每个展开对象都可能增加数百或数千个属性。...在下面的重载示例(为同一功能提供多种功能类型, pickCard 函数将根据用户传入内容返回两个不同内容。如果用户传入表示 deck 对象,则该函数将选择 card。

3.9K10
领券