iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >TypeScript 映射类型是怎样的
  • 711
分享到

TypeScript 映射类型是怎样的

2023-06-22 01:06:36 711人浏览 安东尼
摘要

这期内容当中小编将会给大家带来有关typescript 映射类型是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。前言:TypeScript 的官方文档早已更新,但我能找到的中文文档都还停留

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

前言:

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

1.映射类型(Mapped Types)

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

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

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

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

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

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

type FeatureFlags = {  darkMode: () => void;  newUserProfile: () => void;}; type FeatureOptions = OptionsFlags<FeatureFlags>;// type FeatureOptions = {//    darkMode: boolean;//    newUserProfile: boolean;// }

2.映射修饰符(Mapping Modifiers)

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

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

// 删除属性中的只读属性type CreateMutable<Type> = {  -readonly [Property in keyof Type]: Type[Property];}; type LockedAccount = {  readonly id: string;  readonly name: string;}; type UnlockedAccount = CreateMutable<LockedAccount>;// type UnlockedAccount = {//    id: string;//    name: string;// }// 删除属性中的可选属性type Concrete<Type> = {  [Property in keyof Type]-?: Type[Property];}; type MaybeUser = {  id: string;  name?: string;  age?: number;}; type User = Concrete<MaybeUser>;// type User = {//    id: string;//    name: string;//    age: number;// }

3.通过 as 实现键名重新映射(Key Remapping via as)

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

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

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

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

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

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

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

type EventConfig<Events extends { kind: string }> = {    [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<SquareEvent | CircleEvent>// type Config = {//    square: (event: SquareEvent) => void;//    circle: (event: CircleEvent) => void;// }

4.深入探索(Further Exploration)

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

type ExtractPII<Type> = {  [Property in keyof Type]: Type[Property] extends { pii: true } ? true : false;}; type DBFields = {  id: { format: "incrementing" };  name: { type: string; pii: true };}; type ObjectsNeedingGDPRDeletion = ExtractPII<DBFields>;// type ObjectsNeedingGDPRDeletion = {//    id: false;//    name: true;// }

上述就是小编为大家分享的TypeScript 映射类型是怎样的了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网精选频道。

--结束END--

本文标题: TypeScript 映射类型是怎样的

本文链接: https://www.lsjlt.com/news/301800.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • TypeScript 映射类型是怎样的
    这期内容当中小编将会给大家带来有关TypeScript 映射类型是怎样的,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。前言:TypeScript 的官方文档早已更新,但我能找到的中文文档都还停留...
    99+
    2023-06-22
  • TypeScript映射类型详情
    目录1.映射类型(Mapped Types)2.映射修饰符(Mapping Modifiers)3.通过 as 实现键名重新映射(Key Remapping via as)4.深入探...
    99+
    2024-04-02
  • 深入了解TypeScript中的映射类型
    目录1. 基本概念(1)索引访问类型(2)索引签名(3)联合类型(4)keyof 类型运算符(5)元组类型(6)条件类型2. 映射类型(1)初体验(2)概念(3)实例3. 实用程序中...
    99+
    2022-11-13
    TypeScript映射类型 TypeScript映射
  • 详解TypeScript映射类型和更好的字面量类型推断
    目录概述使用映射类型构建 Object.freeze()映射类型的语法更直观解释更多映射类型的示例映射类型的实际用例更好的字面量类型推断更好的 const 变量推断更好的只读属性推断...
    99+
    2024-04-02
  • ogg中的colmap映射是怎样的
    ogg中的colmap映射是怎样的,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。首先源和目标建表: 源:create table tb0...
    99+
    2024-04-02
  • Python映射类型中dict怎么用
    这篇文章给大家分享的是有关Python映射类型中dict怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。映射类型 - dict字典可用多种方式来创建:使用花括号内以逗号分隔键: 值对的方式: {&ls...
    99+
    2023-06-29
  • 怎样解析TypeScript基础类型
    怎样解析TypeScript基础类型,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。TS 的静态类型可以人为的分为两类:基础类型:像布尔值(boolean)、数字(number)...
    99+
    2023-06-22
  • Elasticsearch的删除映射类型怎么操作
    这篇文章主要讲解了“Elasticsearch的删除映射类型怎么操作”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Elasticsearch的删除映射类型怎么操作”吧!一 前言在elasti...
    99+
    2023-06-30
  • Hibernate中有哪些映射类型
    Hibernate中有哪些映射类型,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.Hibernate内置映射类型1).Java基本类型的Hibernate映射类型Java类型...
    99+
    2023-06-17
  • Python映射类型之dict详解
    目录映射类型—dictlist(d)len(d)d[key]d[key]=valuedeld[key]keyinditer(d)clear()copy()classmet...
    99+
    2024-04-02
  • JPA之映射mysql text类型的问题
    目录JPA之映射mysql text类型问题背景解决方案JPA各种类型映射处理JPA之映射mysql text类型 问题背景 jpa如果直接映射mysql的text/longtext...
    99+
    2024-04-02
  • 映射中的多种函数类型,Golang
    映射是Golang中一种强大的数据结构,它允许我们将一个值与另一个值相关联。在Golang中,我们可以使用映射来实现各种不同类型的函数。php小编柚子将在本文中介绍映射中的多种函数类型...
    99+
    2024-02-12
    golang开发
  • PHP PDO 数据类型映射:让你的数据类型化
    什么是 PDO 数据类型映射? PDO(PHP 数据对象)提供了一个抽象层,可简化与不同数据库的交互。PDO 数据类型映射使我们能够将数据库字段类型映射到 PHP 数据类型。这提供了一致、类型化的和安全的数据库交互体验。 为什么要使用 ...
    99+
    2024-02-17
    PDO PHP 数据类型 映射 数据库
  • Elasticsearch的删除映射类型操作示例
    目录一 前言二 什么是映射类型?三 为什么要删除映射类型?四 映射类型的替代方法4.1 将映射类型分开存储在索引中4.2 自定义类型字段回到顶部五 没有映射类型的父/子六 删除映射类...
    99+
    2024-04-02
  • mybatis怎么利用resultMap复杂类型list映射
    这篇文章主要介绍“mybatis怎么利用resultMap复杂类型list映射”,在日常操作中,相信很多人在mybatis怎么利用resultMap复杂类型list映射问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家...
    99+
    2023-06-20
  • Hiebernate的基本配置和映射类型介绍
    本篇内容介绍了“Hiebernate的基本配置和映射类型介绍”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!<!--标准的XML文件的起...
    99+
    2023-06-17
  • Go语言中的映射类型如何使用?
    Go语言中的映射类型如何使用? 在Go语言中,映射(map)是一种内置的数据结构,用于存储键值对。映射允许通过键来快速检索值,类似于其他语言中的字典或哈希表。在本文中,我们将介绍Go语...
    99+
    2024-04-02
  • MybatisPlus怎么自定义TypeHandler映射JSON类型为List
    这篇文章将为大家详细讲解有关MybatisPlus怎么自定义TypeHandler映射JSON类型为List,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。自定义TypeHandler映射JSON类型为Li...
    99+
    2023-06-28
  • TypeScript的交叉类型和联合类型是什么
    这篇文章主要介绍了TypeScript的交叉类型和联合类型是什么的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇TypeScript的交叉类型和联合类型是什么文章都会有所收获,下面我们一起来看看吧。交叉类型(In...
    99+
    2023-07-04
  • Elasticsearch映射字段数据类型及管理
    目录Elasticsearch映射管理一 映射介绍1.1 字段数据类型1.2 映射参数二 创建索引三 查看索引Elasticsearch映射管理 在Elasticsearch 6.0...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作