TypeScript 之映射类型 TypeScript 的官方文档早已更新,但我能找到的中文文档都还停留在比较老的版本。所以对其中新增以及修订较多的一些章节进行了翻译整理。...映射类型(Mapped Types) 有的时候,一个类型需要基于另外一个类型,但是你又不想拷贝一份,这个时候可以考虑使用映射类型。...映射类型建立在索引签名的语法上,我们先回顾下索引签名: // 当你需要提前声明属性的类型时 type OnlyBoolsAndHorses = { [key: string]: boolean |...MaybeUser>; // type User = { // id: string; // name: string; // age: number; // } 复制代码 通过 as 实现键名重新映射...(Key Remapping via as) 在 TypeScript 4.1 及以后,你可以在映射类型中使用 as 语句实现键名重新映射: type MappedTypeWithNewProperties
映射类型概述 根据 旧 的类型创建出 新 的类型, 我们称之为映射类型 假如如下的 TestInterface1 是旧的类型: interface TestInterface1 { name:...string, age: number } 那么这个时候根据 TestInterface1 创建出来的新的类型就称之为映射类型,例如如下的 TestInterface2: interface...将原有类型中的 部分 内容映射到新类型中 interface TestInterface { name: string, age: number } type MyType = Pick...Record 映射类型 他会将一个类型的所有属性值都映射到另一个类型上并创造一个新的类型 type Animal = 'person' | 'dog' | 'cat'; interface TestInterface...由映射类型进行推断 对于 Readonly,Partial 和 Pick 的映射类型, 我们可以对映射之后的类型进行拆包 还原映射之前的类型, 这种操作我们称之为 拆包 interface MyInterface
[类型+方括号] 在我们创建数组的时候同样我们可以定义数组内数据的类型,如下所示 var arr:number[]=[1,2,3] var arr2:string[]=["1","2","3"] var...arr3:any[]=[1,"2",true] 泛型Array 如下代码所示我们可以以泛型的方式进行创建数组 var arrType:Array=[1,2,3] var arrType1...true] 接口形式 interface IArr{ [index:number]:number } var arrType3:IArr=[1,2,3] 通过如上代码我们限制了值只能为number类型...当然我们也可以约束我们数组里面为我们的对象,我们可定义一个泛型的数组如下所示. interface IArrStudent{ name:string, age:number } var...arrType5:Array=[{ name:"Mr.A",age:18},{ name:"Mr.B",age:20}] 同样在这类型加方括号的形式也可以描述 var arrType6
类型+方括号 在我们创建数组的时候同样我们可以定义数组内数据的类型,如下所示 var arr:number[]=[1,2,3] var arr2:string[]=["1","2","3"] var arr3...:any[]=[1,"2",true] 泛型Array 如下代码所示我们可以以泛型的方式进行创建数组 var arrType:Array=[1,2,3] var arrType1:...true] 接口形式 interface IArr{ [index:number]:number } var arrType3:IArr=[1,2,3] 通过如上代码我们限制了值只能为number类型...当然我们也可以约束我们数组里面为我们的对象,我们可定义一个泛型的数组如下所示. interface IArrStudent{ name:string, age:number } var...arrType5:Array=[{ name:"Mr.A",age:18},{ name:"Mr.B",age:20}] 同样在这类型加方括号的形式也可以描述 var arrType6
简介 JavaScript 数组在 TypeScript 里面分成两种类型,分别是: 数组(array) 元组(tuple) TypeScript 数组有一个根本特征:所有成员的类型必须相同...TypeScript 允许使用方括号读取数组成员的类型。...数组的类型推断 如果数组变量没有声明类型,TypeScript 就会推断数组成员的类型。这时,推断行为会因为值的不同,而有所不同。...如果变量的初始值是空数组,那么 TypeScript 会推断数组类型是any[]。...多维数组 TypeScript 使用T[][]的形式,表示二维数组,T是最底层数组成员的类型。
Mapped Types ---- 有时候对象属性类型重复或者一个类型基于另一个了类型的时候 映射类型基于索引签名的语法构建,用于声明尚未提前声明的属性类型: type OnlyBoolsAndHorses...MaybeUser>; //type User = { //id: string; //name: string; //age: number; //} key 通过as 重新映射...在TypeScript 4.1及更高版本中,您可以使用映射类型中的as子句重新映射映射映射类型中的键: type MappedTypeWithNewProperties = { [...KindlessCircle = RemoveKindField; //type KindlessCircle = { //radius: number; //} 进一步探索 映射类型与此类型操作部分中的其他功能配合得很好...,例如,这里有一个使用条件类型的映射类型,该类型根据对象的属性pii是否设置为文本true返回true或false: type ExtractPII = { [Property in keyof
is only a string 二.映射类型 与索引类型类似,另一种从现有类型衍生新类型的方式是做映射: In a mapped type, the new type transforms each...T = Boxed; 上例中Boxed的True分支具有any[]类型约束,因此能够通过索引访问(T[number])得到数组元素的类型 应用场景 条件类型结合映射类型能够实现具有针对性的类型映射...TypeScript 还内置了一些常用的条件类型: // 从 T 中去掉属于 U 的子类型的部分,即之前示例中的 Diff type Exclude = T extends U ?...R : any; (摘自TypeScript/lib/lib.es5.d.ts) 具体示例见Predefined conditional types 四.总结 除类型组合外,另2种产生新类型的方式是类型查询与类型映射...类型查询: 索引类型:取现有类型的一部分产生新类型 类型映射: 映射类型:对现有类型做映射得到新类型 条件类型:允许以类型兼容关系为条件进行简单的三目运算,用来表达非均匀类型映射 参考资料 Advanced
项目地址:TypeScript-Doc-Zh,如果对你有帮助,可以点一个 star ~ 本章节官方文档地址:Mapped Types 映射类型 有时候我们不想重复编写代码,这时候就需要基于某个类型创建出另一个类型...索引签名用于为那些没有提前声明的属性去声明类型,而映射类型是基于索引签名的语法构建的。...User = { id: string; name: string; age: number; } */ 通过 as 实现键的重新映射...在 TypeScript4.1 或者更高的版本中,你可以在映射类型中使用 as 子句实现键的重新映射: type MappedTypeWithNewProperties = { [...映射类型也可以和本章(类型操控)介绍的其它特性搭配使用。
前言介绍其基本概念、语法特性以及如何开始使用它来构建类型安全的JavaScript应用程序。无论您是新手还是有经验的开发者,都能在这篇文章中找到有关TypeScript的重要信息和实用技巧。...数组类型方式一需求:要求定义一个数组, 这个数组中将来只能存储 数值 类型的数据:let val: Array;val = [1, 3, 5];console.log(val);图片如上代码的含义为表示定义了一个名称叫做...val 的数组, 这个数组中将来只能够存储 数值 类型的数据,错误示例如下:let val: Array;val = [1, 3, 'a'];console.log(val);图片方式二需求...val 的数组, 这个数组中将来只能够存储 字符串 类型的数据,错误示例如下:let val: string[];val = [1, 'b', 'a'];console.log(val);图片联合类型...这个数组中将来可以存储 任意 类型的数据,没有错误示例元祖类型TS 中的元祖类型其实就是数组类型的扩展,元祖用于保存 定长, 定数据类型 的数据let val: [string, number, boolean
在 TypeScript 中声明和初始化数组也很简单,和声明数字类型和字符串类型的变量也差不多,只不过在指定数组类型时要在类型后面加上一个中括号 [] 语法格式 const array_name: dataype...[] = [val, val2]; 示例 声明一个 string 类型的数组 const character: string[] = ["杨过", "小龙女"]; 一维数组类型 声明一个 number..., val2, val3],[v1, v2, v3]]; // 等同于 const array_name: datatype[][] = [[val1, val2, val3]]; 多维数组类型 TypeScript...注意: 以下示例中类型在数组中的,则会限制内层数组的元素数量 Array : 表示内层数组的元素是 string 类型,限制元素数量是 1 个,输入多个会报错 const test3...个 建议: 在定义数组类型的时候使用数组泛型定义,这样显得更直观一点 Tuple 元组类型(元组类型允许表示一个已知元素数量和类型的数组)
索引类型是 TypeScript 中的常见类型,它是聚合多个元素的类型,对象、类、元组等都是索引类型。...: TypeScript 也内置了很多基于映射类型实现的工具类型,比如 Partial、Required 等。...总之,会了映射类型就能够对索引类型做各种变换了。 但是,这些都是对索引类型整体做的变换,变换的结果依然是一个索引类型。 有的时候是想把它们分开的。比如这种需求: 希望能把每个索引给分开。...外层映射类型 [Key in keyof Obj] 就是对每个 Key 做处理,它值也是一个映射类型,而 Key2 来自于刚才的 Key,那么这样映射完之后的类型就是这样的: 这时你取 name 的值就是这样的...总结 索引类型是 TypeScript 中的常见类型,可以通过映射类型的语法来对它做一些修改,生成新的索引类型。
TypeScript 2.1 引入了映射类型,这是对类型系统的一个强大的补充。本质上,映射类型允许w咱们通过映射属性类型从现有类型创建新类型。根据咱们指定的规则转换现有类型的每个属性。...然而,该对象的类型已更改为FrozenPoint,因此其属性被静态类型化为只读。这就是为什么当试图将 42 赋值给 x 属性时,TypeScript 会出错。...这次咱们使用 Point 类型为例来粗略解释类型映射如何工作。...此外,TypeScript 定义了其他映射类型,这些映射类型在各种情况下都非常有用。...更好的字面量类型推断 字符串、数字和布尔字面量类型(如:"abc",1和true)之前仅在存在显式类型注释时才被推断。从 TypeScript 2.1 开始,字面量类型总是推断为默认值。
5、对象的类型——接口 在 TypeScript 中,我们使用接口(Interfaces)来定义对象的类型。...6、数组的类型 在 TypeScript 中,数组类型有多种定义方式,比较灵活。...「类型 + 方括号」表示法 最简单的方法是使用「类型 + 方括号」来表示数组: let fibonacci: number[] = [1, 1, 2, 3, 5]; 数组的项中不允许出现其他的类型: let...类数组 类数组(Array-like Object)不是数组类型,比如 arguments: function sum() { let args: number[] = arguments; }...= arguments; } 其中 IArguments 是 TypeScript 中定义好了的类型,它实际上就是: interface IArguments { [index: number
本文会和大家详细介绍 TypeScript 中的映射类型(Mapped Type),看完本文你将学到以下知识点: 数学中的映射和 TS 中的映射类型的关系; TS 中映射类型的应用; TS 中映射类型修饰符的应用...这样就能很好的实现映射过程的复用。 二、TypeScript 中的映射类型是什么? 1....概念介绍 TypeScript 中的映射类型和数学中的映射类似,能够将一个集合的元素转换为新集合的元素,只是 TypeScript 映射类型是将一个类型映射成另一个类型。...Readonly 只读属性 用来将所有属性的类型设置为只读类型,即不能重新分配类型。...,详细介绍 TypeScript 映射类型(Mapped Type)并介绍映射类型的应用和修饰符的应用。
下面是正文(小册原文): 套路四:数组长度做计数 TypeScript 类型系统不是图灵完备,各种逻辑都能写么,但好像没发现数值相关的逻辑。...这是类型体操的第四个套路:数组长度做计数。 数组长度做计数 TypeScript 类型系统没有加减乘除运算符,怎么做数值运算呢? 不知道大家有没有注意到数组类型取 length 就是数值。...TypeScript 类型系统中没有加减乘除运算符,但是可以通过构造不同的数组然后取 length 的方式来完成数值计算,把数值的加减乘除转化为对数组的提取和构造。...可以正确的算出第 8 个数是 21: 总结 TypeScript 类型系统没有加减乘除运算符,所以我们通过数组类型的构造和提取,然后取长度的方式来实现数值运算。...我们通过构造和提取数组类型实现了加减乘除,也实现了各种计数逻辑。 用数组长度做计数这一点是 TypeScript 类型体操中最麻烦的一个点,也是最容易让新手困惑的一个点。
TypeScript 强大的类型系统使得开发者能够更轻松地编写可维护、可扩展的代码。本文将详细介绍 TypeScript 中的基础类型,包括原始类型、对象类型、数组类型、元组类型、枚举类型和联合类型。...可以使用 类型[] 或者 Array类型> 的语法来声明数组类型。...// 字符串数组元组类型元组类型用于表示一个固定长度和类型的数组。...类型推断和类型断言TypeScript 具有强大的类型推断能力,它可以根据上下文自动推断变量的类型。例如,如果我们在定义变量时直接赋值,TypeScript 可以推断出变量的类型。...总结本文详细介绍了 TypeScript 的基础类型,包括原始类型、对象类型、数组类型、元组类型、枚举类型和联合类型等方面。
TypeScript Array(数组) 数组对象是使用单独的变量名来存储一系列的值。数组在开发中非常常用。...声明数组 TypeScript 声明数组的语法格式如下所示: var 数组名称[:类型]; //声明 数组名称 = [val1,val2,valn..]...//初始化赋值 或者直接在声明时初始化: var 数组名称[:datatype] = [val1,val2…valn]; 如果数组声明时未设置类型,则会被认为是 any 类型,在初始化时根据第一个元素的类型来推断数组的类型...(x); console.log(y); 数组常用方法 1. concat() 连接两个或更多的数组,并返回结果。...var arr = [0, 1, 2, 3].shift(); console.log( arr ); 15. slice() 选取数组的的一部分,并返回一个新数组。
通过这些概念,我们可以更深入地了解TypeScript的映射类型,并通过实际的例子来掌握它们的用法。接下来,我们将逐步展示从简单到高级的7个映射类型的实例,让你轻松掌握这一强大的类型转换工具。...一、布尔类型的转换 在TypeScript中,有时候我们需要将一种类型的属性转换为另一种类型。使用映射类型可以轻松实现这一点。下面我们通过一个具体的例子来展示如何将User类型的属性转换为布尔类型。...在JavaScript中,map函数用于遍历数组并对每个元素执行指定操作。同样,在TypeScript中,映射类型可以遍历类型的每个属性并对其进行转换。...掌握这一技巧可以让你在开发TypeScript应用时更加灵活地处理类型转换问题。 四、将属性设为只读 在TypeScript中,有时我们需要将某个类型的所有属性设为只读。...掌握这一技巧可以让你在开发TypeScript应用时更加灵活地处理类型转换问题。 六、创建仅包含特定类型属性的类型 在TypeScript中,我们可以使用条件类型来创建仅包含某种类型属性的新类型。
TypeScript 给 JavaScript 加了套静态类型系统。其中,JavaScript 中的数组、对象等聚合多个元素的类型在 TypeScript 中对应的是索引类型。...: number; gender: boolean; } 我们知道,TypeScript 支持类型编程,也就是对类型参数(范型)做各种运算,产生新的类型: type IsString = T...true: false; 那么对于索引类型,如何做运算并产生新的类型呢? 答案是映射类型。 映射类型 映射类型就是用于构造新的索引类型的。...如果想实现过滤、转换,那就得用到映射类型的重映射了。 重映射 重映射就是在索引后加一个 as 语句,表明索引转换成什么,它可以用来对索引类型做过滤和转换。...总结 TypeScript 通过索引类型来表示有多个元素的聚合类型,比如数组、对象等。 TS 支持类型编程,也就是对类型参数做各种运算然后返回新的类型。
) 默认 collection="list" 不需要在接口中 @Param,而且这里 “list” 四个字母和接口中的命名不一样没事的,因为会自动根据类型映射...;数组 “array” 同理可得。
领取专属 10元无门槛券
手把手带您无忧上云