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篇类型体操,等你哟😎

相关推荐
下雪天的夏风3 小时前
TS - tsconfig.json 和 tsconfig.node.json 的关系,如何在TS 中使用 JS 不报错
前端·javascript·typescript
天下无贼!17 小时前
2024年最新版TypeScript学习笔记——泛型、接口、枚举、自定义类型等知识点
前端·javascript·vue.js·笔记·学习·typescript·html
Jorah3 天前
1. TypeScript基本语法
javascript·ubuntu·typescript
小白小白从不日白4 天前
TS axios封装
前端·typescript
aimmon4 天前
Superset二次开发之源码DependencyList.tsx 分析
前端·typescript·二次开发·bi·superset
下雪天的夏风5 天前
Vant 按需引入导致 Typescript,eslint 报错问题
前端·typescript·eslint
theMuseCatcher5 天前
Vue3+TypeScript+Vite+Less 开发 H5 项目(amfe-flexible + postcss-pxtorem)
typescript·less·postcss
Qiyandays5 天前
vue + Lodop 制作可视化设计页面 实现打印设计功能(四)
前端·vue.js·typescript
人工智能的苟富贵5 天前
微信小程序中的模块化、组件化开发:完整指南
微信小程序·小程序·typescript
Code blocks8 天前
小试牛刀-区块链Solana多签账户
算法·typescript·区块链·github