작성
·
53
·
수정됨
0
6.5 에러핸들링 24:04 (with-searchbar) 레이아웃을 살리기위해 error.tsx를 app/book/[id] 로 옮겨도 <Searchbar />가 보이지 않는 현상이 있습니다. 그리고 영상에서도 app/book/[id] 가 에러인 상황임에도 검색바 레이아웃이 보이는 장면이 없어서 헷갈리는 것 같습니다!
답변 2
1
안녕하세요 이정환입니다.
book 페이지에는 원래 서치바 레이아웃이 나타나지 않습니다.
따라서 오류 상태에도 서치바 레이아웃이 잘 보이는지 확인하시려면
인덱스 페이지 혹은 서치 페이지에 접속해 확인해 보실것을 추천드립니다.
0
안녕하세요, 인프런 AI 인턴입니다.
IHP개발님께서 문의하신 내용은 Next.js에서 Suspense
와 에러 핸들링 시 레이아웃 유지 문제와 관련된 것 같습니다. 이와 관련하여 몇 가지 참고할 수 있는 정보를 드리도록 하겠습니다.
Next.js에서는 클라이언트 측에서 에러 페이지를 처리하기 위해 error.tsx
컴포넌트를 특정 경로에 배치할 수 있습니다. 하지만 Suspense
를 사용한 경우, Suspense
로 감싼 컴포넌트에서 에러가 발생하면 Suspense
의 fallback
UI로 대체되며, 이 과정에서 레이아웃이 사라질 수 있습니다.
검색바가 보이지 않는 이유:
- Suspense
바깥쪽에 Searchbar
를 배치해야 전체적인 레이아웃이 유지되며 에러가 발생해도 검색바가 보이게 됩니다.
- 또, error.tsx
에 정의된 에러처리 로직은 해당 경로 하위에서 발생한 에러를 처리합니다. 따라서, Searchbar
가 다른 레이아웃에 포함되지 않았을 수도 있습니다.
참고할 만한 유사한 Q&A:
1. 에러 발생 시 전체 레이아웃 유지하기
위의 게시물들을 참고하여 Suspense
와 에러 핸들링 부분에서 전체 레이아웃을 관리하는 방법을 이해하시면 도움이 될 것 같습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
감사합니다!