해결된 질문
작성
·
12
0
useEffect(() => {
const controller = new AbortController();
const fetchPosts = async () => {
try {
setIsLoading(true);
const { data } = await axiosInstance.get(
`/posts?_page=${currentPage}&_limit=${limit}&q=${encodeURIComponent(searchText)}`,
{
signal: controller.signal,
},
);
setPosts(data);
} catch (e) {
console.log(e);
if (e instanceof Error && e.name !== "CanceledError") {
if (e.message.includes("timeout")) {
setError("timeout 오류 발생");
} else {
setError(e.message);
}
}
} finally {
if (!controller.signal.aborted) setIsLoading(false);
}
};
fetchPosts();
return () => {
controller.abort();
};
}, [currentPage, limit, searchText]);
처음 실행 시(새로고침)
console.log(e)
에서
CanceledError {message: 'canceled', name: 'CanceledError', code: 'ERR_CANCELED', config: {…}, request: XMLHttpRequest, …}
이렇게 무조건 잡히는데 왜 그럴 까요? 물론 프로그램 실행 에는 문제가 없습니다.
답변 3
0
0
0
안녕하세요, 인프런 AI 인턴입니다. jyuvenia님.
useEffect
훅을 사용하는 코드에서 CanceledError
가 발생하는 이유는 다음과 같습니다. useEffect
는 컴포넌트가 마운트되거나 의존성 배열 내의 값이 변경될 때마다 실행됩니다. 이 과정에서 이전에 시작된 비동기 요청이 여전히 진행 중인 경우, AbortController
를 사용해 해제(abort)하면서 CancelledError
가 발생하게 됩니다.
간단히 요약하자면, React 컴포넌트의 재랜더링 또는 언마운트 과정에서 요청이 중단되면서 CanceledError
가 발생하는 것입니다. 이 오류는 자연스러운 동작이며 별도의 프로그램 실행에는 영향을 주지 않으므로 걱정하지 않으셔도 됩니다.
CanceledError
에 대한 핸들링을 하지 않으시거나, 콘솔에 출력되지 않도록 조치하시면 불필요한 오류 기록을 피할 수 있습니다.
추가로, 이와 관련된 유사한 사례나 해결 방안이 궁금하시면, 아래의 질문과 답변 링크를 참고해보세요.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.