data:image/s3,"s3://crabby-images/c7609/c760961cb5faa12f4cb5a1ef45efe655180a0189" alt="Next.JS의 Layout 시스템"
1. Layout
: 필요한 것을 복사 붙여넣기 없이 어디서나 사용할 수 있는 시스템
2. Layout 적용 과정
- layout component에 있는 export된 default component를 렌더링 → 실제 렌더링
- 이동하려는 페이지를 URL을 통해 인식 → component(layout component의 children prop)를 렌더링
- TypeScript) children의 타입이 ReactNode
- children이 실제 내가 이동하려는 페이지
import Navigation from "./components/navigation" export const metadata = { title: 'Next.js', description: 'Generated by Next.js', } export default function RootLayout({ children, }: { children: React.ReactNode }) { return ( <html lang="en"> <body> <Navigation /> {children} </body> </html> ) }
3. 특정 Layout 만들기
- 해당 URL 폴더에 layout.tsx 파일 만들기
- 기존의 layout.tsx 파일 복사 붙여넣기 해서 틀 잡고 수정하기
export default function AboutUsLayout({ children, }: { children: React.ReactNode }) { return ( <div> {children} © Next JS is great! </div> ) }
data:image/s3,"s3://crabby-images/857ee/857eef56aa197e9feff7a831393ac0748f5366a2" alt="notion image"
data:image/s3,"s3://crabby-images/4a8bf/4a8bf2711424da8ea33fb24a31459cd11c86fc81" alt="notion image"
- 해당 URL 내에 페이지 만들기
- 새로운 페이지의 layout이 없는 경우 상위 폴더의 layout이 적용되어있음
export default function Sales() { return ( <div> <h1>Sales jobs</h1> </div> ); }
data:image/s3,"s3://crabby-images/3f50c/3f50c799de21976beef15ad73be2baf036a1a801" alt="notion image"
data:image/s3,"s3://crabby-images/fb8c5/fb8c55f179280f6259551dedd7106eaf1d168e30" alt="notion image"
- Layout은 중첩이 가능함
data:image/s3,"s3://crabby-images/26dd8/26dd8f6e864e98fb03df557bab04a3e8f96118b9" alt="notion image"
data:image/s3,"s3://crabby-images/7918a/7918ae3a6cb576c4411fc6d886cac4f9eebf1a89" alt="notion image"
data:image/s3,"s3://crabby-images/1a894/1a8944693f670c372a5bf8963eaec16bf4c9f282" alt="notion image"
Share article