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
- java
- Gin
- golang
- designpatterns
- storybook
- Spring
- ReactHooks
- hook
- backend
- javascript
- component
- React
- satisfiles
- Chakra
- 티스토리챌린지
- JavaSpring
- go
- typescript
- frontend
- JPA
- Redux
- RTK
- react-hook-form
- css
- tanstackquery
- test
- 오블완
- springboot
- 웹애플리케이션서버
Archives
- Today
- Total
bkdragon's log
ReplaceAll 본문
문자열에서 특정부분을 모두 찾아 대체하는 타입을 만들어보자.
템플릿 리터럴 타입과 재귀를 이용해줘야 한다. 다만 이때 신경써야 하는 포인트는 이미 대체된 이후로 재귀가 되어야 한다는 것이다.
특정 부분이 대체되고 나서의 문자열에 대체하려는 요소가 새롭게 생겨나도 지나간 부분이기에 무시해줘야 한다.
type ReplaceAll<S extends string, From extends string, To extends string> =
From extends ''
? S
: S extends `${infer F}${From}${infer R}`
? `${F}${To}${ReplaceAll<R, From, To>}`
: S
From을 To 대체하고 남은 부분 (R)부터 재귀에 들어가는 것을 볼 수 있다. 간단해보여도 어려운 문제였다!
'Typescript' 카테고리의 다른 글
팩토리 메서드, 추상 팩토리 패턴 (0) | 2024.11.09 |
---|---|
Absolute (1) | 2023.10.29 |
문자열의 길이 구하기 (1) | 2023.10.21 |
as < satisfies (0) | 2023.08.04 |
satisfies 키워드란? (0) | 2023.07.02 |