Network Security Internet Technology Development Database Servers Mobile Phone Android Software Apple Software Computer Software News IT Information

In addition to Weibo, there is also WeChat

Please pay attention

WeChat public account

Shulou

What is the type of TypeScript mapping

2025-10-25 Update From: SLTechnology News&Howtos shulou NAV: SLTechnology News&Howtos > Development >

Share

Shulou(Shulou.com)06/02 Report--

这期内容当中小编将会给大家带来有关TypeScript 映射类型是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

前言:

TypeScript 的官方文档早已更新,但我能找到的中文文档都还停留在比较老的版本。所以对其中新增以及修订较多的一些章节进行了翻译整理。

1.映射类型(Mapped Types)

有的时候,一个类型需要基于另外一个类型,但是你又不想拷贝一份,这个时候可以考虑使用映射类型。

映射类型建立在索引签名的语法上,我们先回顾下索引签名:

// 当你需要提前声明属性的类型时type OnlyBoolsAndHorses = { [key: string]: boolean | Horse;}; const conforms: OnlyBoolsAndHorses = { del: true, rodney: false,};

而映射类型,就是使用了 PropertyKeys 联合类型的泛型,其中 PropertyKeys 多是通过 keyof 创建,然后循环遍历键名创建一个类型:

type OptionsFlags = { [Property in keyof Type]: boolean;};

在这个例子中,OptionsFlags 会遍历 Type 所有的属性,然后设置为布尔类型。

type FeatureFlags = { darkMode: () => void; newUserProfile: () => void;}; type FeatureOptions = OptionsFlags;// type FeatureOptions = {// darkMode: boolean;// newUserProfile: boolean;// }2.映射修饰符(Mapping Modifiers)

在使用映射类型时,有两个额外的修饰符可能会用到,一个是 readonly,用于设置属性只读,一个是 ? ,用于设置属性可选。

你可以通过前缀 - 或者 + 删除或者添加这些修饰符,如果没有写前缀,相当于使用了 + 前缀。

// 删除属性中的只读属性type CreateMutable = { -readonly [Property in keyof Type]: Type[Property];}; type LockedAccount = { readonly id: string; readonly name: string;}; type UnlockedAccount = CreateMutable;// type UnlockedAccount = {// id: string;// name: string;// }// 删除属性中的可选属性type Concrete = { [Property in keyof Type]-?: Type[Property];}; type MaybeUser = { id: string; name?: string; age?: number;}; type User = Concrete;// type User = {// id: string;// name: string;// age: number;// }3.通过 as 实现键名重新映射(Key Remapping via as)

在 TypeScript 4.1 及以后,你可以在映射类型中使用 as 语句实现键名重新映射:

type MappedTypeWithNewProperties = { [Properties in keyof Type as NewKeyType]: Type[Properties]}

举个例子,你可以利用「模板字面量类型」,基于之前的属性名创建一个新属性名:

type Getters = { [Property in keyof Type as `get${Capitalize}`]: () => Type[Property]}; interface Person { name: string; age: number; location: string;} type LazyPerson = Getters;// type LazyPerson = {// getName: () => string;// getAge: () => number;// getLocation: () => string;// }

你也可以利用条件类型返回一个 never 从而过滤掉某些属性:

// Remove the 'kind' propertytype RemoveKindField = { [Property in keyof Type as Exclude]: Type[Property]}; interface Circle { kind: "circle"; radius: number;} type KindlessCircle = RemoveKindField;// type KindlessCircle = {// radius: number;// }

你还可以遍历任何联合类型,不仅仅是 string | number | symbol 这种联合类型,可以是任何类型的联合:

type EventConfig = { [E in Events as E["kind"]]: (event: E) => void;} type SquareEvent = { kind: "square", x: number, y: number };type CircleEvent = { kind: "circle", radius: number }; type Config = EventConfig// type Config = {// square: (event: SquareEvent) => void;// circle: (event: CircleEvent) => void;// }4.深入探索(Further Exploration)

映射类型也可以跟其他的功能搭配使用,举个例子,这是一个使用条件类型的映射类型,会根据对象是否有 pii 属性返回 true 或者 false :

type ExtractPII = { [Property in keyof Type]: Type[Property] extends { pii: true } ? true : false;}; type DBFields = { id: { format: "incrementing" }; name: { type: string; pii: true };}; type ObjectsNeedingGDPRDeletion = ExtractPII;// type ObjectsNeedingGDPRDeletion = {// id: false;// name: true;// }上述就是小编为大家分享的TypeScript 映射类型是怎样的了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注行业资讯频道。

Welcome to subscribe "Shulou Technology Information " to get latest news, interesting things and hot topics in the IT industry, and controls the hottest and latest Internet news, technology news and IT industry trends.

Views: 0

*The comments in the above article only represent the author's personal views and do not represent the views and positions of this website. If you have more insights, please feel free to contribute and share.

Share To

Development

Wechat

© 2024 shulou.com SLNews company. All rights reserved.

12
Report