반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- typescript
- 타입 챌린지
- Node.js
- 자바스크립트
- dp
- 타입스크립트
- Algorithm
- 알고리즘
- 그래프
- 프로그래머스
- Crawling
- socket
- type challenge
- BFS
- TCP
- 백준
- 문자열
- HTTP 완벽 가이드
- 소켓
- 가천대
- HTTP
- Nestjs
- ip
- dfs
- 프로그래머스 레벨 2
- 레벨 1
- 크롤링
- 수학
- javascript
- 쉬운 문제
Archives
- Today
- Total
kakasoo
TupleToUnion 타입 정의하기 본문
반응형
type Arr = ['1', '2', '3']
type Test = TupleToUnion<Arr> // expected to be '1' | '2' | '3'
answer
type TupleToUnion<T extends any[]> = any
type TupleToUnion<T extends any[]> = T[number];
답을 먼저 제시한다.
답을 추론해 나가는 과정도 아래 서술하겠지만, 사실 이런 서술을 무시하고도 Tuple을 Union으로 변환하는 게 저게 전부임을,
직관적으로 깨닫는 사람도 분명 있을 거라 생각한다.
type TupleToUnion<T extends any[]> = T['length'] extends 0 ? never : T[number];
type TupleToUnion<T extends any[]> = T extends [] ? never : T[number];
논리를 따라가면, T는 any[]를 확장하며, T의 length가 0이면 never, 그렇지 않다면 T[number]인 타입이라고 할 수 있다.
그러면 T['length']인 정수 중 0을 제외한 나머지로 이루어진 타입이기 때문에 유니온이 될 것이다.
이것은 다시 두 번째 줄처럼 변경할 수 있다.
length가 0이라는 것은 빈 배열이라는 의미기 때문이다.
다음으로 얘기할 것은, 전자의 never 타입은 어차피 결코 나올 수 없는 경우의 수라는 점이다.
type TupleToUnion<T extends any[]> = T extends [] ? T[number] : T[number];
type TupleToUnion<T extends any[]> = T extends [] ? T[0] : T[number];
사실 T가 빈 배열인 [] 타입인 시점에서, T[0] 이든 T[1] 이든 무얼 넣어도 같다.
빈 배열에 인덱스를 넣고 가리켜 봐야 결국 never이기 때문이다.
여기서는 이 인덱스를 0으로 한정하여, 아래와 같이 변경할 것이다.
그러면 처음에 얘기했던 대로 T[number]는 0이 아닌 나머지 정수들을 의미하고, 전자는 T[0]이기 때문에 참, 거짓을 합치면,
type TupleToUnion<T extends any[]> = T[number];
이런 타입이 된다.
never 타입을 왜 마음대로 바꿀 수 있는지는 아래 글을 보면서 생각해보자.
반응형
'프로그래밍 > TypeScript' 카테고리의 다른 글
Chainable, 연쇄적인 호출이 가능한 타입 (0) | 2023.02.21 |
---|---|
앞 글자가 대문자인 문자열 타입 정의하기 (0) | 2023.02.19 |
Readonly type 구현 (0) | 2023.02.15 |
infer R 타입을 이용한 GetReturnType (0) | 2023.02.12 |
Omit type 정의하기 & Type level에서 as문 사용하기 (0) | 2023.02.10 |