• 카테고리

    질문 & 답변
  • 세부 분야

    프론트엔드

  • 해결 여부

    미해결

useMutation의 onError에 관하여 질문있습니다.

24.05.05 13:22 작성 조회수 51

0

안녕하세요. 제로초님 항상 좋은 강의 감사드립니다.

 

해당 강의에서 팔로우 api에 의도적으로 에러를 일으켜 보았는데, onError에서 캐치하지 못하는 것을 확인했습니다.

 

  
  const follow = useMutation({
    mutationFn: (userId: string) => {
      // console.log('follow', userId);
      return fetch(
        `${process.env.NEXT_PUBLIC_BASE_URL}/api/users/${userId}/follow`,
        {
          credentials: 'include',
          method: 'post',
        }
      );
    },
    ...

    onError(error, userId: string) {
     ...
     }

 

그래서 밑에와 같이 바꾸어보니 onError에서 캐치하여 롤백이 정상적으로 되었습니다.

    mutationFn: async (userId: string) => {
      const response = await fetch(
        `${process.env.NEXT_PUBLIC_BASE_URL}/api/users/${userId}/follow`,
        {
          credentials: 'include',
          method: 'post',
        }
      );
      if (!response.ok) {
        throw new Error('팔로우 실패');
      }
      return response;
    },

혹시 본 강의 코드대로 하면 onError에서 원래 캐치해야하는데 안 되는 것인지 아니면 수강생들에게 숙제로 낸 것인지 궁금합니다.

답변 1

답변을 작성해보세요.

1

저게 axios는 에러가 발생하는데 fetch는 400이나 500 에러도 일단 성공한 걸로 쳐서 onError가 발생하지 않습니다. 400 500 대 상태 코드 응답인 경우 작성하신 것처럼 직접 throw 하셔야 합니다.