반응형
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 |
Tags
- 자바스크립트
- ip
- 타입 챌린지
- BFS
- 레벨 1
- 크롤링
- dp
- Algorithm
- dfs
- socket
- 소켓
- typescript
- Crawling
- 프로그래머스 레벨 2
- HTTP 완벽 가이드
- Nestjs
- 그래프
- 알고리즘
- HTTP
- javascript
- type challenge
- 문자열
- 쉬운 문제
- 백준
- 수학
- Node.js
- TCP
- 타입스크립트
- 가천대
- 프로그래머스
Archives
- Today
- Total
kakasoo
재귀적으로 카멜케이스로 추론되는 객체 타입 본문
반응형
type SnakeToCamelCaseObject<T extends object> = {
[K in keyof T as SnakeToCamel<ToString<K>>]: T[K] extends object
? SnakeToCamelCaseObject<T[K]>
: T[K];
};
const c: SnakeToCamelCaseObject<{
a_b: {
c_d: {
e_f: {
g_h: true;
};
};
};
i_j: false;
}> = {
aB: {
cD: {
eF: {
gH: true,
},
},
},
iJ: false,
};
카멜케이스 타입을 재귀적으로 돌게 하면 위와 같이 스네이크 케이스로 만들어진 타입을 재귀적으로 카멜 케이스가 되게 수정할 수 있다.
컨벤션을 일괄적으로 변경하기에 용이하다.
문자열을 카멜케이스로 변경하는 타입은 아래에서 확인할 수 있다.
SnakeCase에서 CamelCase로 리터럴 타입 추론하기
type SnakeToCamel< Target extends string, P extends string[] = Split > = Join; 타입 파라미터 Target을 받는다. 이 타입 Target을 _ 문자를 기준으로 Split하면 문자열이 배열의 형태가 되는데, 이를 일단 P에 저장한다.
kscodebase.tistory.com
반응형
'프로그래밍 > TypeScript' 카테고리의 다른 글
Currying, 인자를 커링으로 변경하는 타입 (1) | 2023.12.03 |
---|---|
타입만으로 클래스의 메서드를 한 번만 호출 가능하게 만들기 (0) | 2023.12.03 |
SnakeCase에서 CamelCase로 리터럴 타입 추론하기 (0) | 2023.08.11 |
FirstLetterCapitalize, 첫 글자를 대문자로 추론하는 리터럴 타입 (0) | 2023.08.11 |
문자열을 자르는 Split 타입 구현하기 (0) | 2023.08.11 |