大家好,我是苏先生,一名热爱钻研、乐于分享的前端工程师,跟大家分享一句我很喜欢的话:人活着,其实就是一种心态,你若觉得快乐,幸福便无处不在
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
那么,拿当前推断出来的F
去U
里找
如果没找到,则说明F
尚不存在重复,但这不能代表整个F
在T
中不重复,因此,还需要从剩余的R
中找是否存在重复
ts
F extends R[number] ? '递归剔除':'记录结果并递归'
一旦找到重复,就将F
记录进U
,并递归去剔除F
ts
FindOnceAppearAtArray<R, U | F>
此时如果还是找不到,则说明F
在整个T
中唯一,此时需要将其作为结果记录下来。并对R递归,这样就能依次找T中的第二、第三、...第n个是否重复并在唯一时进行记录了
ts
[F, ...FindOnceAppearAtArray<R, U>]
现在的关键点在于,如何做到递归剔除,也即F
去U
里找,找到的情况如何处理。如下,只需要将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篇类型体操,等你哟😎