【类型挑战】实现 Omit,难度⭐️⭐️

简介: 【类型挑战】实现 Omit,难度⭐️⭐️

知识运用:


  1. 什么是Omit
  2. 如何遍历联合类型?
  3. 使用内置的Exclude。


题目分析:


题目地址:3-medium-omitimage.png

如上图所示,我们需要实现的通用类型工具的要求需要满足可以将传入的对象在忽略掉指定key的字段后再返回输出。


题目解答:


测试用例:

我们的测试用例需要满足按需省略掉对象中存在的属性,当需要省略的属性不存在时将会抛出错误。

/* _____________ 测试用例 _____________ */
import { Equal, Expect } from '@type-challenges/utils'
type cases = [
  Expect<Equal<Expected1, MyOmit<Todo, 'description'>>>,
  Expect<Equal<Expected2, MyOmit<Todo, 'description' | 'completed'>>>
]
// @ts-expect-error
type error = MyOmit<Todo, 'description' | 'invalid'>
interface Todo {
  title: string
  description: string
  completed: boolean
}
interface Expected1 {
  title: string
  completed: boolean
}
interface Expected2 {
  title: string
}
复制代码


答案及解析:

  1. 观察测试用例,我们传入的K有两个特点,一个是K必须存在T中,另一个是需要使用keyof来得到T中属性组成的联合类型。
  2. 接着我们需要使用内置的Exclude来从T的属性组成的联合类型中排除K的存在。
  3. 通过in来遍历剩余的属性,并通过索引类型访问来读取每个U的值,最后组成一个U:T[U]。
/* _____________ 你的代码 _____________ */
type MyOmit<T, K extends keyof T> = {
  [U in Exclude<keyof T, K>]: T[U]
}
复制代码


去演练场验证答案



相关文章
|
6月前
|
存储 算法
【编码狂想】LeetCode 字符串和数组篇:挑战算法精髓,深化程序设计基础
【编码狂想】LeetCode 字符串和数组篇:挑战算法精髓,深化程序设计基础
54 0
|
开发工具
每天一道 CodeForces 构造/思维题 难度1500 (day3)
每天一道 CodeForces 构造/思维题 难度1500 (day3)
|
测试技术 索引
【类型挑战】最后一个元素,难度⭐️⭐️
【类型挑战】最后一个元素,难度⭐️⭐️
117 0
【类型挑战】最后一个元素,难度⭐️⭐️
|
测试技术
【类型挑战】深度 Readonly,难度⭐️⭐️
【类型挑战】深度 Readonly,难度⭐️⭐️
309 0
【类型挑战】深度 Readonly,难度⭐️⭐️
|
机器学习/深度学习 存储 容器
【综合笔试题】1044. 最长重复子串 : 两种强有力的字符串处理方式
【综合笔试题】1044. 最长重复子串 : 两种强有力的字符串处理方式
|
JavaScript 前端开发 测试技术
【类型挑战】出栈,难度⭐️⭐️
【类型挑战】出栈,难度⭐️⭐️
145 0
【类型挑战】出栈,难度⭐️⭐️
|
前端开发 测试技术
【类型挑战】Awaited,难度⭐️
【类型挑战】Awaited,难度⭐️
127 0
【类型挑战】Awaited,难度⭐️
|
测试技术
【类型挑战】If,难度⭐️
【类型挑战】If,难度⭐️
110 0
【类型挑战】If,难度⭐️
|
测试技术
【类型挑战】Readonly 2,难度⭐️⭐️
【类型挑战】Readonly 2,难度⭐️⭐️
148 0
【类型挑战】Readonly 2,难度⭐️⭐️
|
测试技术 API
【类型挑战】元组转联合,难度⭐️⭐️
【类型挑战】元组转联合,难度⭐️⭐️
175 0
【类型挑战】元组转联合,难度⭐️⭐️