상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - switchMap에서 필터링을 추가하는 방법은?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
switchMap 연산자는 RxJS에서 주로 내부 Observable을 다룰 때 사용됩니다. 어떤 Observable이 방출하는 값에 따라 새로운 Observable로 전환(switch)하고 그 결과를 방출하는 역할을 하죠. 그런데 switchMap을 사용할 때 필터링 조건을 추가해서 특정 값들만 처리하고 싶으면 어떻게 해야 할까요? 먼저 이해해야 할 점은 switchMap 자체는 변환(mapping) 연산자이며, 직접적인 필터링 기능은 없습니다. 즉, switchMap 안에서 값의 필터링을 하려면 보통 다음 두 가지 방법 중 하나를 사용합니다. 1. switchMap 바깥쪽에서 필터링하기 switchMap을 적용할 Observable이 방출하는 값에 대해 먼저 filter 연산자를 사용하여 조건에 맞는 값만 통과시키는 방법입니다. 예를 들어, `source$.pipe(filter(value => value > 10), switchMap(...))` 처럼 하면 10보다 큰 값만 switchMap이 처리하게 됩니다. 2. switchMap 내부에서 필터링하기 switchMap 안에서 새 Observable을 생성할 때, 내부 Observable에서 filter 연산자를 적용할 수 있습니다. 예를 들면: ```typescript source$.pipe( switchMap(value => innerObservable$.pipe( filter(innerValue => innerValue === value) )) ) ``` 이렇게 하면 source$ 에서 받은 값에 대해 내부 Observable의 값 중 특정 조건에 맞는 값만 방출됩니다. 3. 조건에 따른 switchMap 분기 처리 switchMap을 호출하기 전에 조건문을 두어 특정 조건에 따라 다른 Observable로 전환하거나 빈 Observable을 반환하는 방법입니다. 예를 들어: ```typescript source$.pipe( switchMap(value => { if (value > 10) { return someObservable(value); } else { return EMPTY; // 아무것도 방출하지 않고 끝내는 Observable } }) ) ``` 이렇게 하면 조건에 맞지 않는 값에 대해 아무 결과도 내지 않습니다. 요약하자면, switchMap에서 필터링을 추가하려면 switchMap 앞뒤로 filter를 적용하거나, switchMap 내부에서 filter를 사용하는 방법, 또는 조건문으로 분기 처리하는 방법을 조합해서 활용할 수 있습니다. 상황에 맞게 가장 적합한 방식을 선택하시면 됩니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기