반응형
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
- 자바스크립트
- ip
- typescript
- javascript
- dfs
- 백준
- dp
- socket
- Node.js
- HTTP 완벽 가이드
- 그래프
- 타입 챌린지
- 소켓
- 프로그래머스
- Nestjs
- type challenge
- 레벨 1
- 프로그래머스 레벨 2
- 타입스크립트
- 문자열
- TCP
- 크롤링
- 수학
- HTTP
- 쉬운 문제
- Crawling
- Algorithm
- BFS
- 알고리즘
- 가천대
Archives
- Today
- Total
kakasoo
Trim, 글 양쪽의 빈 문자열들을 제거한 타입 본문
반응형
type TrimLeft<S extends string> = S extends ` ${infer Rest}` | `\n${infer Rest}` | `\t${infer Rest}` ? TrimLeft<Rest> : S;
type TrimRight<S extends string> = S extends `${infer Rest} ` | `${infer Rest}\n` | `${infer Rest}\t` ? TrimRight<Rest> : S;
type Trim<S extends string> = TrimRight<TrimLeft<S>>;
TrimLeft, Right를 구현한 후 이를 합성하는 것이 훨씬 더 쉽다.
처음에는 쓸 데 없는 욕심에 Trim을 extends로 쭉 나열했는데 가독성만 나빠졌다.
반응형
'프로그래밍 > TypeScript' 카테고리의 다른 글
Replace, 처음으로 만난 단어를 대체하여 새 문자열 만들기 (0) | 2023.03.22 |
---|---|
PromiseAll type (0) | 2023.03.21 |
TrimRight (0) | 2023.03.21 |
TrimLeft (0) | 2023.03.20 |
Flatten (0) | 2023.03.19 |