인프런 커뮤니티 질문&답변

IHP개발님의 프로필 이미지
IHP개발

작성한 질문수

한 입 크기로 잘라먹는 Next.js(15+)

6.5) 에러 핸들링 (error.tsx)

6.5 에러핸들링 24:04 (with-searchbar) 레이아웃이 살아나지 않음

작성

·

53

·

수정됨

0

스크린샷 2024-11-08 오후 7.31.42.png스크린샷 2024-11-08 오후 7.32.02.png

6.5 에러핸들링 24:04 (with-searchbar) 레이아웃을 살리기위해 error.tsx를 app/book/[id] 로 옮겨도 <Searchbar />가 보이지 않는 현상이 있습니다. 그리고 영상에서도 app/book/[id] 가 에러인 상황임에도 검색바 레이아웃이 보이는 장면이 없어서 헷갈리는 것 같습니다!

답변 2

1

이정환 Winterlood님의 프로필 이미지
이정환 Winterlood
지식공유자

안녕하세요 이정환입니다.

book 페이지에는 원래 서치바 레이아웃이 나타나지 않습니다.

따라서 오류 상태에도 서치바 레이아웃이 잘 보이는지 확인하시려면

인덱스 페이지 혹은 서치 페이지에 접속해 확인해 보실것을 추천드립니다.

IHP개발님의 프로필 이미지
IHP개발
질문자

감사합니다!

0

안녕하세요, 인프런 AI 인턴입니다.

IHP개발님께서 문의하신 내용은 Next.js에서 Suspense와 에러 핸들링 시 레이아웃 유지 문제와 관련된 것 같습니다. 이와 관련하여 몇 가지 참고할 수 있는 정보를 드리도록 하겠습니다.

Next.js에서는 클라이언트 측에서 에러 페이지를 처리하기 위해 error.tsx 컴포넌트를 특정 경로에 배치할 수 있습니다. 하지만 Suspense를 사용한 경우, Suspense로 감싼 컴포넌트에서 에러가 발생하면 Suspensefallback UI로 대체되며, 이 과정에서 레이아웃이 사라질 수 있습니다.

검색바가 보이지 않는 이유:
- Suspense 바깥쪽에 Searchbar를 배치해야 전체적인 레이아웃이 유지되며 에러가 발생해도 검색바가 보이게 됩니다.
- 또, error.tsx에 정의된 에러처리 로직은 해당 경로 하위에서 발생한 에러를 처리합니다. 따라서, Searchbar가 다른 레이아웃에 포함되지 않았을 수도 있습니다.

참고할 만한 유사한 Q&A:
1. 에러 발생 시 전체 레이아웃 유지하기

  1. 배치 컴포넌트가 Suspense 내부 UI에 영향을 미칠 때 해결 방법

위의 게시물들을 참고하여 Suspense와 에러 핸들링 부분에서 전체 레이아웃을 관리하는 방법을 이해하시면 도움이 될 것 같습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

IHP개발님의 프로필 이미지
IHP개발

작성한 질문수

질문하기