3. 实现 Readonly
简单
实现 TypeScript 内置的工具类型 Readonly<T>
,但不可以使用它。
它的作用是接收一个泛型参数 T
,并返回一个完全一样的类型,只是所有属性都会被 readonly
所修饰。
也就是不可以对该对象的属性重新赋值。
例如:
interface Todo {
title: string
description: string
}
const todo: MyReadonly<Todo> = {
title: "Eat",
description: "Eat some food"
}
todo.title = "Sleep" // Error: cannot reassign a readonly property
todo.description = "Sleep at 9:00" // Error: cannot reassign a readonly property
上述代码中如果对象变量 todo
的任何一个属性被重新赋值,会有类型报错。