【ts类型体操】03060-easy-unshift

这篇博客探讨了如何在TypeScript中实现类型版本的`unshift`操作。作者首先展示了JavaScript的实现方式,然后详细解释了如何在TypeScript中达到相同效果,强调了新元素将位于数组首位的关键点。内容还引用了一个相关的GitHub链接,提供了更深入的挑战详情。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

需求:实现类型版本的 Array.unshift

type Unshift<T extends any[], U> = any
import type { Equal, Expect } from '@type-challenges/utils'
import { ExpectFalse, NotEqual } from '@type-challenges/utils'

type cases = [
  Expect<Equal<Unshift<[], 1>, [1]>>,
  Expect<Equal<Unshift<[1, 2], 0>, [0, 1, 2 ]>>,
  Expect<Equal<Unshift<['1', 2, '3'], boolean>, [boolean, '1', 2, '3']>>,
]

先用js的思路写一遍:

  1. 返回一个数组
  2. unshift新元素是在第一位,所以将U放在解构赋值数组的前面
 function unshiftNum(T,U){
   return [U,...T]
 }

再想想ts怎么写:

  1. 返回一个数组  √
  2. unshift新元素是在第一位,所以将U放在解构赋值数组的前面  √
type Unshift<T extends any[], U> = [U,...T]

题目链接:type-challenges/README.zh-CN.md at main · type-challenges/type-challenges · GitHubicon-default.png?t=M3K6https://github.com/type-challenges/type-challenges/blob/main/questions/03060-easy-unshift/README.zh-CN.md

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值