TypeScript类型体操--获取数组的中间元素

大家好,我是苏先生,2024年我的第一愿景就是做一个可行的副业,求大佬带我~~

好文推荐

前言

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

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

提示

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

实现

这个工具类型实现起来还是比较简单的,只需要在数组的首尾放两个指针,并每次向中间各移动一位即可

假设数组是[number,number,number,number,number,number,number],则指针初始位置在0和6的位置

由于指针所表示的元素是即将被抛弃的元素,所以我们可以使用any来表示,也就是下边这样

ts 复制代码
[any,...,any]

至于中间的部分,则使用infer进行提取就行

ts 复制代码
[any,... infer M,...any]

infer推倒出来的剩余部分,重复前边两步就行了,也就是递归

既是递归,就涉及到出口

显然,当数组的成员数为0或1或2时,得到的中间元素始终是数组本身

设工具类型为GetMiddleElement,入参为T且约束为数组类型

ts 复制代码
type GetMiddleElement<T extends any[]>

当其长度

ts 复制代码
T['length']

为0/1/2时,递归结束

ts 复制代码
type GetMiddleElement<T extends any[]> = T['length'] extends 0|1|2 ? T : ...

否则,指针移动,使用infer提取出剩余部分M

ts 复制代码
T extends [any,...infer M,any]

对M继续递归

ts 复制代码
GetMiddleElement<M>

故,完整的代码如下

ts 复制代码
type GetMiddleElement<T extends any[]> = 
  T['length'] extends 0 | 1 | 2?
    T:
    T extends [any,...infer M,any]?
      GetMiddleElement<M>:never

使用示例如下

拓展

思考一下,如果想要得到的是对应的中间元素的下标,应该怎么处理呢?

思考一下,感兴趣的,可以评论区贴出答案哦🥰

下期预告

AppendArgument

  • 功能

为函数追加参数

  • 使用示例
ts 复制代码
type Fn = (a: number, b: string) => number

type case = AppendArgument<Fn, boolean>  
// (a: number, b: string, x: boolean) => number

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

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

相关推荐
Din6 小时前
主动取消的防抖
前端·javascript·typescript
决斗小饼干6 小时前
跨语言移植手记:把 TypeScript 的 Codex SDK 请进 .NET 世界
前端·javascript·typescript
Wect12 小时前
LeetCode 17. 电话号码的字母组合:回溯算法入门实战
前端·算法·typescript
IT星宿1 天前
开发一个 TypeScript 语言服务插件:让 RTK Query 的"跳转到定义"更智能
typescript·redux
不会敲代码12 天前
Zustand:轻量级状态管理,从入门到实践
前端·typescript
不会敲代码13 天前
从零开始用 TypeScript + React 打造类型安全的 Todo 应用
前端·react.js·typescript
赵小胖胖3 天前
解决方案与原理解析:TypeScript 中 Object.keys() 返回 string[] 导致的索引类型丢失与优雅推导方案
typescript
minge5 天前
借助 Trae Builder 把 TypeScript 的碎片化学习记录整理成文档
typescript
骑着小黑马5 天前
从 Electron 到 Tauri 2:我用 3.5MB 做了个音乐播放器
前端·vue.js·typescript
ZengLiangYi5 天前
并发 401 下的 Token 刷新竞态:一个被低估的 Bug
typescript