상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - switchMap을 사용할 때 권장되는 패턴은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
switchMap은 RxJS에서 매우 유용한 연산자로, 주로 Observable이 방출하는 값에 따라 내부 Observable을 바꾸고 이전에 구독한 Observable을 자동으로 취소(cancel)할 때 사용합니다. 하지만 switchMap을 사용할 때 권장되는 패턴과 주의사항이 있습니다. 아래에 자세히 설명합니다. 1. 내부 Observable은 반드시 <a href='https://sangseek.com/sangseeks/완결/ko'>완결</a>되는 스트림이어야 한다 switchMap의 목적은 구독을 새로운 내부 Observable로 전환하는 것이므로, 내부 Observable이 무한히 emit하지 않고 적절히 완료(complete)되는 Observable이어야 합니다. 예) HTTP 요청 Observable처럼 한 번 응답하고 완료되는 스트림이 이상적입니다. 만약 내부 Observable이 완료되지 않는 무한 스트림이라면, switchMap이 새로운 Observable로 전환되더라도 이전 스트림이 취소되면서 리소스 누수나 예상치 못한 동작이 발생할 수 있습니다. 2. Observable 변환 시 매핑 함수는 즉시 Observable을 반환해야 한다 switchMap 내부 매핑 함수에서는 무조건 Observable을 반환해야 하며, 비동기 처리를 할 때는 Observable 생성에 신경 써야 합니다. 예) `switchMap(value => httpClient.get(...))` 즉시 Observable을 반환하여 내부 스트림을 전환하는 방식이어야 하며, Promise나 콜백을 그냥 넣으면 안 됩니다. 3. 기본적으로 앞선 요청을 취소하고 최신 데이터만 반영하는 경우에 사용 switchMap은 이전 내부 Observable을 취소해버리므로, 예를 들어 검색창 입력에 따른 <a href='https://sangseek.com/sangseeks/자동완성/ko'>자동완성</a> 기능 구현 시 사용하면 강력합니다. 입력을 빠르게 치면 이전 요청이 취소되고 마지막 입력 기준 결과만 받아 옵니다. 이 패턴은 “사용자 입력에 따른 최신값 반영”에 매우 효과적입니다. 4. 에러 핸들링은 내부 Observable 또는 외부에서 별도로 처리해야 한다 switchMap 내부에서 발생하는 에러가 외부 스트림 전체를 중단시키지 않게 하기 위해서는 내부 Observable에서 catchError 등을 잘 적용하거나 switchMap 밖에서 에러를 처리하는 로직을 설계하는 것이 좋습니다. 5. 내부 Observable이 너무 빨리 바뀌어도 안전하게 처리해야 한다 switchMap은 내부 Observable이 아직 완료되지 않았는데도 새로운 값이 들어오면 이전 스트림을 즉시 취소합니다. 따라서 “취소가 가능한” Observable인지, 취소 시 의도치 않은 부작용이 생기지는 않는지 반드시 확인해야 합니다. 6. 필요에 따라 다른 연산자와 조합해서 사용 예를 들어, `debounceTime`과 함께 사용하여 빠른 연속 입력을 필터링하거나, `distinctUntilChanged`로 입력값이 실제로 변경된 경우에만 switchMap을 실행하도록 해 불필요한 내부 Observable 생성과 취소를 방지할 수 있습니다. 7. 가능한 한 최소화된 내부 Observable 생성 로직 내부 Observable을 생성하는 복잡한 로직을 switchMap에 직접 넣기보다, 별도의 함수로 분리하여 가독성과 재사용성을 높이는 것이 좋습니다. --- 요약 - switchMap 내부에는 완료되는 Observable을 반환한다. - 이전 Observable은 자동 취소되므로, 취소 시 부작용이 없는 구조여야 한다. - 텍스트 입력, API 요청 등 “마지막 이벤트만 처리”해야 하는 곳에 적합하다. - debounceTime, distinctUntilChanged와 조합해 불필요한 실행을 줄인다. - 에러는 내부 또는 외부에서 별도로 처리한다. - 내부 Observable 생성 로직은 명확하고 간결하게 작성한다. 이런 패턴을 따르면 switchMap의 장점을 최대한 활용하면서도 예기치 않은 문제를 예방할 수 있습니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기