跳到主要内容

Readonly

不要使用内置的 Readonly<T>,自己实现一个泛型 Readonly<T> 会接收一个 泛型参数,并返回一个完全一样的类型,只是所有属性都会是只读 (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

答案

Details
type MyReadonly<T> = {
readonly [k in keyof T]: T[k]
}