TypeScript 类型挑战:元组转换为对象

开发 前端
一些前端面试中考察到了 TypeScript 高级类型的定义,本系列主要解答来自 Type Challenges 项目中的 TS 类型挑战问题,以此更好的了解 TS 的类型系统,编写自己的类型工具,更好的应对前端面试。

高质量的类型可以提高项目的可维护性并避免一些潜在的漏洞。

一些前端面试中考察到了 TypeScript 高级类型的定义,本系列主要解答来自 Type Challenges 项目中的 TS 类型挑战问题,以此更好的了解 TS 的类型系统,编写自己的类型工具,更好的应对前端面试。

下面来看一个难度为简单的题目:元组转换为对象

题目描述

传入一个元组类型,将这个元组类型转换为对象类型,这个对象类型的键/值都是从元组中遍历出来。

例如:

const tuple = ['tesla', 'model 3', 'model X', 'model Y'] as const

type result = TupleToObject<typeof tuple>
// expected { tesla: 'tesla', 'model 3': 'model 3', 'model X': 'model X', 'model Y': 'model Y'}

题目解答

我们需要从数组中获取所有值,并将其作为新对象中的键和值。

首先我们知道什么是元组,来看TypeScript 对元组的定义:

元组类型是另一种Array类型,它确切地知道包含多少个元素,以及它在特定位置包含哪些类型。

这意味着我们可以检查length并得到确切的数字:

const fullName:[first: string, last: string] = ['hello', 'world'];
const range:[start: number, end: number] = [0, 10];
const digits = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] as const;

type FullNameLength = (typeof fullName)['length'] // 2
type RangeLength = (typeof range)['length'] // 2
type DigitsLength = (typeof digits)['length'] // 10

而在数组中就无法实现这一点:

const fullName:string[] = ['hello', 'world'];
const range:number[] = [0, 10];

type FullNameLength = (typeof fullName)['length'] // number
type RangeLength = (typeof range)['length'] // number

可以使用映射类型来遍历对象:

type MappedType<T> = {
[Key in keyof T]: T[Key];
};
  • keyof T用于从对象类型T中获取键值 key;
  • in用于对对象键值key进行迭代;
  • Key 就是对象键值 key 本身;
  • T[Key]是指定 Key 的值;

我们使用索引访问类型来遍历元组,可以通过T[number]从元组中获取值。具体实现如下:

type TupleToObject<T> = {
[Value in T[number]]: Value;
};
  • T[number] 用于从元组 T 中获取值;
  • in 用于迭代元组值;
  • Value 是元组元素,用作构建对象的key和value。

但是这时候报错了:

这时就需要约束泛型的类型,最终的实现如下:

type TupleToObject<T extends readonly any[]> = {
[Value in T[number]]: Value;
};

这里的extends readonly any[] 是调用T[number] 所必须的,用来约束 T 的类型,T是一个元组,元组元素是只读的。

Type Challenges:https://github.com/type-challenges/type-challenges

责任编辑:武晓燕 来源: 前端充电宝
相关推荐

2024-03-26 06:53:41

Python元组转换JSON对象

2022-05-04 09:02:41

TypeScript类型工具

2009-07-15 16:56:59

Jython类型Java类型

2023-07-12 08:29:58

TypeScrip元组元素

2022-06-01 08:12:32

JS类数组对象

2023-10-16 09:26:48

CSS类型转换

2011-06-01 10:19:41

基类对象派生类对象

2023-03-03 10:26:49

Python内建库模块

2021-01-18 08:52:28

Java对象多态

2009-07-14 09:06:08

Java对象类型转换

2016-12-14 09:07:54

日期转换中文

2010-10-27 13:25:33

Oracle查询

2022-09-20 14:43:55

TypeScript类型体操

2009-06-05 11:16:58

字符串动态转换

2021-01-13 05:18:50

数据类型性能

2022-02-25 09:06:02

TypeScripnever工具

2021-07-27 06:06:34

TypeScript语言运算符

2021-08-30 07:22:15

Go类型interface

2021-08-18 07:56:05

Typescript类型本质

2022-04-11 08:42:09

TypeScript子类型定义
点赞
收藏

51CTO技术栈公众号