상식닷컴
로그인
가입하기
2026년 상식닷컴 선정 식당 & 카페 리스트
2025년 2026년 신상 호텔 리스트
최근에 오픈한 호텔을 찾는다면 살펴보세요
일주일 식단표 어플
자동 일주일 식단표 어플
안드로이드
아이폰
주식 & 코인 차트의 신
1000만원으로 2000만원 만들기 프로젝트
수정하기 - switchMap을 사용하여 데이터 로딩 상태를 나타내는 방법은 무엇인가요?
닉네임
비밀번호
제목
내용
[이미지 업로드는 권한이 있는 사람만 가능. 하단 카톡으로 연락]
`switchMap` 연산자는 RxJS에서 주로 Observable을 변환하고, 이전에 발행된 내부 Observable을 취소하며 새로운 Observable로 전환할 때 사용됩니다. 비동기 데이터 로딩 작업을 처리할 때도 자주 활용되죠. 데이터 로딩 상태(예: 로딩 중, 성공, 실패 등)를 `switchMap`과 함께 표현하는 방법에 대해 자세히 설명드리겠습니다. --- 상황 설명 예를 들어, 사용자가 입력한 검색어를 기반으로 API 데이터를 요청한다고 가정해볼게요. 이때 사용자는 빠르게 여러 번 입력할 수 있고, 각 요청이 비동기로 처리되기 때문에 가장 최근 입력에 대한 요청 결과만 보여줘야 합니다. 또한 요청이 시작되면 "로딩 중" 표시를 하고, 요청이 완료되면 데이터를 화면에 보여주며, 만약 에러가 발생하면 에러 메시지를 출력해야 합니다. 이 상황에서 `switchMap`과 로딩 상태 표현을 어떻게 조합할지 설명합니다. --- 1. 기본 아이디어 - 로딩 시작 : 새로운 입력이 들어오고 API 호출이 시작되면 로딩 상태를 `<a href='https://sangseek.com/sangseeks/true/ko'>true</a>`로 설정한다. - 응답 도착 / 실패 : 요청 완료 시(성공/실패)에 로딩 상태를 `false`로 변경한다. --- 2. 구현 방법 방법 A: 별도의 상태 관리 (예: BehaviorSubject) 사용하기 - `loading$` 라는 별도의 Subject나 BehaviorSubject를 만든다. - 검색어 스트림이 새로운 값이 들어올 때마다 로딩 상태를 `true`로 변경한다. - `switchMap` 내부 API 호출 Observable이 완료되거나 에러 시 `loading$` 를 `false`로 변경한다. ```typescript import { Subject, BehaviorSubject, of } from 'rxjs'; import { switchMap, tap, catchError } from 'rxjs/operators'; const searchTerms$ = new Subject<string>(); const loading$ = new BehaviorSubject<boolean>(false); const data$ = searchTerms$.pipe( tap(() => loading$.next(true)), // API 호출 직전에 로딩 true 변경 switchMap(term => apiCall(term).pipe( tap(() => loading$.next(false)), // 성공 시 로딩 false catchError(error => { loading$.next(false); // 에러 발생 시에도 로딩 false // 에러처리 방법에 따라 에러 Observable 반환 혹은 빈 데이터 전달 return of(null); }) ) ) ); ``` 이 방법은 `loading$`를 구독하여 UI 컴포넌트가 로딩 상태에 따라 표시를 조절할 수 있게 합니다. --- 방법 B: 상태를 객체 형태로 묶어서 반환하기 Observable 데이터가 `{ loading, data, error }` 같은 객체 형태로 값을 내보내도록 만들어 컴포넌트가 구독하면 한 주체로 상태 관리가 가능합니다. ```typescript import { of } from 'rxjs'; import { switchMap, startWith, catchError, map } from 'rxjs/operators'; const searchTerms$ = new Subject<string>(); const result$ = searchTerms$.pipe( switchMap(term => apiCall(term).pipe( map(data => ({ loading: false, data, error: null })), catchError(error => of({ loading: false, data: null, error })), startWith({ loading: true, data: null, error: null }) // 호출 시작 시 로딩 true 전송 ) ) ); ``` - `startWith`를 통해 `loading: true` 상태를 먼저 내보내고, - API 콜 성공 시 `loading: false`와 데이터를 세팅, - 실패 시 `loading: false`와 에러를 세팅합니다. 이 방식은 하나의 스트림에서 로딩 상태, 데이터, 에러를 관리할 수 있다는 장점이 있습니다. --- 3. 요약 및 주의사항 - `switchMap` 사용 시 내부 Observable이 전환될 때 이전 호출이 취소되므로, 항상 가장 최신 API 요청 결과만 처리한다. - 로딩 상태는 `switchMap` 직전에 변경하거나, API 호출 Observable 내부에서 상태를 갱신한다. - 에러 상황도 반드시 처리하여 로딩 상태가 무한히 로딩 중인 상태로 빠지지 않도록 주의해야 한다. - 상황에 따라 별도의 상태 스트림(`loading$`)을 두거나 하나의 상태 객체를 내보내는 방식 중 선택한다. --- 이와 같이 `switchMap`을 활용하면 사용자 입력에 따른 빠른 비동기 처리와 상태 관리가 간결하게 구현 가능합니다.
이용안내
커뮤니티 이용안내
×
- 게시한 게시글로 발생하는 문제는 게시자에게 책임이 있습니다.
- 게시글이 타인/타업체의 저작권을 침해할 경우 모든 책임은 게시자에게 있습니다. 게시자가 모든 손해를 부담해야 합니다.
- 상식닷컴 운영자는 게시자와 상의하지 않고 게시글을 수정 또는 삭제할 수 있습니다.
- 상식닷컴 운영자는 깨끗한 커뮤니티 공간을 만드는 것이 1순위입니다.
수정하기
취소하기