TypeScript类型体操--FindOnceAppearAtArray

大家好,我是苏先生,一名热爱钻研、乐于分享的前端工程师,跟大家分享一句我很喜欢的话:人活着,其实就是一种心态,你若觉得快乐,幸福便无处不在

github与好文

前言

前边十篇文章我们一共实现了38 个工具类型,按照本专栏的规划,还差61个...

本节我们继续学习一个新的工具类型

提示

对于语法层面的知识点本系列(类型体操开头的标题)不会展开说明哈,可以自行搜索学习其他大佬的优质文章或者等我后续更新补充

实现

首先,老规矩,使用type自定义一个名为FindOnceAppearAtArray的新类型,并且它接受两个泛型参数

ts 复制代码
type FindOnceAppearAtArray<T extends any[],U = never>

接着,对泛型参数T构造条件类型,这不仅能对用户传递T做校验,也能够通过infer提取出当前要参与逻辑运算的F。如下,F表示数组的第一个成员,R则表示剩余成员

ts 复制代码
T extends [infer F,...infer R]

我们的目的是将重复的成员剔除,所以需要一个变量来标记出现重复的key,也就是一开始创建的泛型参数U

那么,拿当前推断出来的FU里找

如果没找到,则说明F尚不存在重复,但这不能代表整个FT中不重复,因此,还需要从剩余的R中找是否存在重复

ts 复制代码
F extends R[number] ? '递归剔除':'记录结果并递归'

一旦找到重复,就将F记录进U,并递归去剔除F

ts 复制代码
FindOnceAppearAtArray<R, U | F>

此时如果还是找不到,则说明F在整个T中唯一,此时需要将其作为结果记录下来。并对R递归,这样就能依次找T中的第二、第三、...第n个是否重复并在唯一时进行记录了

ts 复制代码
[F, ...FindOnceAppearAtArray<R, U>]

现在的关键点在于,如何做到递归剔除,也即FU里找,找到的情况如何处理。如下,只需要将F丢弃并对剩余的R进行递归就好了

ts 复制代码
FindOnceAppearAtArray<R, U> 

最后,需要保证返回的类型以及为递归找出口。如下,当倒数第2次,即T中只有一个成员时,R为空,下一次将进入falsy的结果,此时取[]返回,就保证了递归结束,并且在记录最终结果的递归中使用扩展运算符不出错

ts 复制代码
T extends [
  infer F,
  ...infer R
] ? '...' : []

故,使用示例如下

下期预告

Square

  • 功能

获取平方数

  • 使用示例
ts 复制代码
type case = Square<4> // 16

如果本文对您有用,希望能得到您的点赞和收藏

订阅专栏,每周更新1-2篇类型体操,等你哟😎

相关推荐
j喬乔1 小时前
Node导入不了命名函数?记一次Bug的探索
typescript·node.js
yg_小小程序员12 小时前
vue3中使用vuedraggable实现拖拽
typescript·vue
高山我梦口香糖14 小时前
[react 3种方法] 获取ant组件ref用ts如何定义?
typescript·react
prall16 小时前
实战小技巧:下划线转驼峰篇
前端·typescript
一條狗2 天前
隨筆 20241224 ts寫入excel表
开发语言·前端·typescript
轻口味3 天前
配置TypeScript:tsconfig.json详解
ubuntu·typescript·json
小林rr4 天前
前端TypeScript学习day03-TS高级类型
前端·学习·typescript
web150850966414 天前
前端TypeScript学习day01-TS介绍与TS部分常用类型
前端·学习·typescript
前端熊猫5 天前
省略内容在句子中间
前端·javascript·typescript
禁止摆烂_才浅5 天前
React全家桶 -【高阶函数/高阶组件/钩子】-【forwardRef、mome、useImperativeHandle、useLayoutEffect】
react.js·typescript