前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【类型挑战】Push,难度⭐️

【类型挑战】Push,难度⭐️

作者头像
前端小鑫同学
发布2022-12-26 10:54:47
5770
发布2022-12-26 10:54:47
举报
文章被收录于专栏:小鑫同学编程历险记

Dear,大家好,我是“前端小鑫同学”,😇长期从事前端开发,安卓开发,热衷技术,在编程路上越走越远~

知识运用:

  1. 条件类型的灵活运用;
  2. 分布式条件类型的灵活运用;题目分析: 题目地址:3057-easy-push
image.png
image.png

题目解答: 测试用例:

代码语言:javascript
复制
/* _____________ 测试用例 _____________ */
import { Equal, Expect, ExpectFalse, NotEqual } from '@type-challenges/utils'

type cases = [
  Expect<Equal<Push<[], 1>, [1]>>,
  Expect<Equal<Push<[1, 2], '3'>, [1, 2, '3']>>,
  Expect<Equal<Push<['1', 2, '3'], boolean>, ['1', 2, '3', boolean]>>,
]
复制代码
答案及解析:

第一次尝试解答:

  1. 我们同样做一下传入类型的约束,通过常用手法泛型类型来做;
  2. 如何将用例中的数组+数组和数组+元素合并?我们可以采用结构后合并到一个数组中;
  3. 那么我们就可以通过条件类型来判断是否为数组来进行不同的解构做拼接得到了下面的答案;
代码语言:javascript
复制
/* _____________ 答案,未能全部通过测试用例 _____________ */
type Push<T extends any[], U> = U extends any[] ? [...T, ...U] : [...T, U];
复制代码

第二次尝试解答:

  1. 第一次尝试的答案未能通过第三条测试用例;
  2. 我们通过typeA1 = Push<['1', 2, '3'], boolean>;发现输出类型编程了联合类型,而非我们需要的Boolean类型,那么我们就想到了分布式条件类型的默认行为;
  3. 如何处理分布式条件默认行为呢?官方文档给出了答案,我们可以使用中括号给extends两侧的类型进行包裹来避免这种默认行为,得到下面可以全部通过的答案;
代码语言:javascript
复制
/* _____________ 答案,可有全部通过测试用例 _____________ */
type Push<T extends any[], U> = [U] extends [any[]] ? [...T, ...U] : [...T, U];
复制代码

第三次尝试解答:

  1. 在这里我们还可以再次使用条件类型来判断U的类型是否为Boolean来直接返回boolean或返回U得到下面的答案;
代码语言:javascript
复制
/* _____________ 答案,可有全部通过测试用例 _____________ */
type Push<T extends any[], U> = U extends any[] ? [...T, ...U] : [...T, U extends boolean ? boolean : U];
复制代码

接下来的一题是:【类型挑战】Unshift,难度⭐️

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-11,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 知识运用:
    • 答案及解析:
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档