이 글은 제가 타입챌린지를 하면서 해석한 내용을 적는 글입니다. 틀린 내용이 있으면 댓글 달아주시면 감사하겠습니다.
https://github.com/type-challenges/type-challenges/blob/main/questions/03060-easy-unshift/README.md
type Unshift<T extends any[], U> = [U, ...T];
// test case
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']>>,
]
Push의 문제 풀이랑 똑같다.
type Unshift : Unshift 라는 타입을 정의한다.
<T extends any[], U> = [U, ...T]; : 전개연산자를 사용해야하기 때문에 T에 배열을 상속한다. 그리고 [U, ...T] 를 통해 배열 T 앞에 U를 넣으면 끝!
참고
'Language > Typescript' 카테고리의 다른 글
타입챌린지 : 2-Get Return Type (medium) (0) | 2023.03.08 |
---|---|
타입챌린지 : 3312-Parameters (easy) (0) | 2023.03.06 |
타입챌린지 : 3057-Push (easy) (0) | 2023.03.06 |
타입챌린지 : Equal - 번외 (0) | 2023.03.06 |
타입챌린지 : 898-Includes (easy) (0) | 2023.03.05 |