-
Notifications
You must be signed in to change notification settings - Fork 1
Outlet을 활용한 공통 레이아웃 관리 ‐ 2024.11.11
Dongwoo Ko edited this page Nov 20, 2024
·
1 revision
새로운 페이지(StocksDetail)를 만들려고 하다보니 Header 역시 동일하게 필요했다.
다음과 같은 형태로 컴포넌트가 구성되었다.
function App() {
return (
<Router>
<Routes>
<Route index element={<Home />} />
<Route path='stocks/:id' element={<StocksDetail />} />
</Routes>
</Router>
);
}
export default function Home() {
return (
<>
<Header />
<div className='flex flex-col gap-4 pt-[60px]'>
<StockIndex />
<TopFive />
</div>
<Login />
</>
);
}
export default function StocksDetail() {
return (
<>
<Header />
<div className='flex flex-col gap-4 pt-[60px]'>
// stocksdetail...
</div>
<Login />
</>
);
}
Home하고 StocksDetail에 중복되는 컴포넌트들이 보인다. Header
와 Login
!
지금은 두 개의 페이지라 괜찮을 지 몰라도 페이지가 점점 늘어나다 보면 이 동일한 작업을 계속 해줘야 하는데 너무 비효율적이라 생가했다. 공통 컴포넌트는 하나의 공통 레이아웃으로 분리할 수 없을까??
react-router-dom
에 Outlet
을 사용하면 해결할 수 있다.
부모 컴포넌트에 Outlet
을 정의하고,
그 부모 컴포넌트를 가지는 상위 route의 자식 route들의 컴포넌트가 Outlet
자리에 렌더링 된다.
아래 코드를 보면 Layout
이 부모(상위 컴포넌트)이고, Home
, StocksDetail
이 하위(자식 컴포넌트)이다.
부모 Layout
을 기반으로 Outlet
위치에 Home
과 StokcsDetail
이 route 경로에 따라 그려진다!
function App() {
return (
<Router>
<Routes>
<Route path='/' element={<Layout />}>
<Route index element={<Home />} />
<Route path='stocks/:id' element={<StocksDetail />} />
</Route>
</Routes>
</Router>
);
}
export default App;
function Layout() {
return (
<>
<Header />
<main className='mt-[60px] flex flex-col gap-4'>
<Outlet />
</main>
<Login />
</>
);
}
export default function Home() {
return (
<>
<StockIndex />
<TopFive />
</>
);
}
export default function StocksDetail() {
return <>// stocksdetail...</>;
}
Outlet
을 활용해 중복 레이아웃을 제거해 유지보수에 유리한 코드를 작성할 수 있었다!
https://hsly22xk.tistory.com/405
https://reactrouter.com/en/main/components/outlet
- [FE] 프론트엔드 기술스택
- [FE] 라이브러리 없이 차트 구현 이유
- [FE] Canvas API 사용방법
- [FE] 네비게이션 바 애니메이션 구현
- [FE] Socket.io 사용방법
- [FE] Tanstack Router에 대하여...
- [FE] Intl(Internationalization) API
- [FE] React Suspense 적용
- [FE] 한글 입력 방식의 유연성을 높인 검색 시스템 구현하기
- [BE] 백엔드 기술 스택
- [BE] SSE vs Socket.io
- [BE] Redis를 도입하게 된 계기
- [BE] ACG Rule을 활용한 Secure CI CD 파이프라인 구현
- [BE] Nginx 로드밸런싱을 통해 한국 투자 API 소켓 제한 극복
- [BE] 주가 지수 기능 개발 과정
- [BE] 매수 및 매도 기능 개발 과정
- [BE] 실시간 자산 조회 기능 개발 과정
- [BE] 단위 테스트
- [BE] redis를 이용한 한국투자 Open API 세션 관리
- [BE] 데이터베이스 인덱싱
- [FE] React에서의 DOM 요소 접근 (useRef vs getElementById)
- [FE] Outlet을 활용한 공통 레이아웃 관리
- [FE] react hooks가 특정 조건에서 실행되면 안되는 이유 & useQuery에 query function 매개변수가 undefined일 수도 있을 때 어떻게 해결할까
- [FE] cross‐domain 로컬 환경에서 cookie로 인증 처리하기 with vite proxy
- [FE] 크롬&사파리 Composition 차이
- [FE] useEffect 의존성 배열
- [BE] Naver Cloud Platform HTTPS 무응답 현상
- [BE] 한국투자 Open API에서 access token을 발급받지 못하는 문제
- [BE] 한국투자 Open API와 웹소켓 연결이 되지 않던 문제
- [BE] 한국투자 Open API 웹소켓 연결이 중단되는 문제
- [BE] 같은 주식 주문이 동시에 여러 번 체결되는 문제
- [BE] 한국투자 Open API Websocket 세션을 두 개에서 한 개로 변경하기
- [BE] Nginx 로드 밸런싱 중 Socket bad Request 발생하는 현상
- [BE] 매수/매도 체결 로직에 의해 redis pub/sub이 정상적으로 동작하지 않는 문제