3. 实现 Readonly

简单2

实现 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 的任何一个属性被重新赋值,会有类型报错。

评论(0)
题库

TypeScript

加载中...