代码拉取完成,页面将自动刷新
/*
4 - 实现 Pick
-------
by Anthony Fu (@antfu) #简单 #union #built-in
### 题目
> 欢迎 PR 改进翻译质量。
实现 TS 内置的 `Pick<T, K>`,但不可以使用它。
**从类型 `T` 中选择出属性 `K`,构造成一个新的类型**。
例如:
```ts
interface Todo {
title: string
description: string
completed: boolean
}
type TodoPreview = MyPick<Todo, 'title' | 'completed'>
const todo: TodoPreview = {
title: 'Clean room',
completed: false,
}
```
> 在 Github 上查看:https://tsch.js.org/4/zh-CN
*/
/* _____________ 你的代码 _____________ */
type MyPick<T,K extends keyof T> = {[P in K]:T[P];}
/* _____________ 测试用例 _____________ */
import type { Equal, Expect } from '@type-challenges/utils'
type cases = [
Expect<Equal<Expected1, MyPick<Todo, 'title'>>>,
Expect<Equal<Expected2, MyPick<Todo, 'title' | 'completed'>>>,
// @ts-expect-error
MyPick<Todo, 'title' | 'completed' | 'invalid'>,
]
interface Todo {
title: string
description: string
completed: boolean
}
interface Expected1 {
title: string
}
interface Expected2 {
title: string
completed: boolean
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。