其他
TypeScript 类型挑战:实现 Readonly
高质量的类型可以提高项目的可维护性并避免一些潜在的漏洞。
一些大厂在前端面试中也考察到了 TypeScript 高级类型的定义,本系列主要解答来自 Type Challenges 中的 TS 类型挑战问题,以此更好的了解 TS 的类型系统,编写自己的类型工具。
本系列持续更新,欢迎关注!下面来看一个难度为简单的题目:实现 Readonly
题目描述
不要使用内置的Readonly<T>
,自己实现一个。
该 Readonly
会接收一个 _泛型参数_,并返回一个完全一样的类型,只是所有属性都会被 readonly
所修饰。
也就是不可以再对该对象的属性赋值。
例如:
interface Todo {
title: string
description: string
}
const todo: MyReadonly<Todo> = {
title: "Hey",
description: "foobar"
}
todo.title = "Hello" // Error: cannot reassign a readonly property
todo.description = "barFoo" // Error: cannot reassign a readonly property
题目解答
Readonly
与 Pick
类似,通常在需要声明基于另一种类型的类型时使用。生成的类型的第一层的值是只读的。
与 Pick 一样,我们需要使用映射类型来遍历对象:
type MappedType<T> = {
[Key in keyof T]: T[Key];
};
keyof T
用于从对象类型T中获取键值key
;in
用于对对象键值key
进行迭代;Key
就是对象键值key
本身;T[Key]
是指定Key
的值;
为了使对象的第一层属性不可变,我们需要使用 readonly
修饰符:
type MyReadonly<T> = {
readonly [Key in keyof T]: T[Key];
}
Type Challenges:https://github.com/type-challenges/type-challenges