Post

[CSS] header가 잘리는 현상

header가 전체를 차지하지 못하고 잘리는 현상

[CSS] header가 잘리는 현상

문제 - 1

만든 헤더가 화면이 커졌을 때, 전체를 차지하지 못하고 잘리는 현상이 일어났습니다.

Image

트러블슈팅

Image

개발자 도구를 사용하여 문제가 생기는 부분을 찾아보니, root에 이렇게 마진이 들어간 것을 확인할 수 있었습니다.

#root의 css는 다음과 같습니다.

1
2
3
4
5
#root {
	max-width: 1500px;
	margin: 0 auto;
	text-align: center;
}

왜… 왜 max-width를 잡아놨던 걸까요…? 개발자 도구에서 이걸 삭제해주니 제대로 화면을 차지하는 것을 볼 수 있었습니다.

내친 김에 화면 크기를 3000으로 더 늘려봤습니다.

문제 - 2

Image

크기가 높이에 맞게 늘어나지 않고 고정되어 있습니다. 저는 커진 화면만큼 Outlet 부분이 맞춰지길 바랬는데요.

조금 수정한 원래 코드는 아래와 같습니다. 모든 페이지에서 헤더를 주고 싶어서 Layout으로 감쌌습니다.

1
2
3
4
5
6
7
8
9
10
const Layout = () => {
	return (
		<div className='flex flex-col w-full items-center relative'>
			<Header />
			<div className='w-full pt-16'>
				<Outlet />
			</div>
		</div>
	)
}

min-h-screenmin-w-full을 추가해봤습니다.

  • min-w-full : 최소 너비를 부모 요소의 100%로 설정합니다. 즉, 적어도 부모 요소만큼의 너비는 무조건 가지게 됩니다.

    • w-full과의 차이점 : w-full은 너비를 부모의 100%로 “고정”하지만, min-w-full은 최소 너비만 100%로 설정하고 컨텐츠가 더 크다면 그만큼 늘어날 수 있습니다.
  • min-h-screen : 최소 높이를 viewport(화면) 높이의 100%로 설정합니다. 즉, 적어도 화면 높이만큼은 무조건 차지하게 됩니다.

    • h-screen과의 차이점 : h-screen은 높이를 viewport 높이로 “고정”하지만, min-h-screen은 최소 높이만 viewport 높이로 설정하고 컨텐츠가 더 크다면 그만큼 늘어날 수 있습니다.
1
2
3
4
5
6
7
8
9
10
11
12
const Layout = () => {
  return (
    // min-h-screen을 추가해서 최소한 화면 높이만큼은 차지하도록
    // min-w-full을 추가해서 화면 너비를 모두 차지하도록
    <div className='flex flex-col min-h-screen min-w-full items-center relative'>
      <Header />
      <div className='w-full pt-16'>
        <Outlet />
      </div>
    </div>
  )
}

Image

제가 원하던 것과는 조금 달랐습니다. 요소의 크기가 화면에 딱 맞았으면 좋겠습니다.

트러블슈팅 - 2

저 부분을 채울 flex-1 이 생각났습니다. Outlet을 감싸는 divflex-1을 사용해서 Header를 제외한 남은 공간을 모두 채우도록 해봤습니다.

1
2
3
4
5
6
7
8
9
10
const Layout = () => {
	return (
		<div className='flex flex-col min-h-screen min-w-full items-center relative'>
			<Header />
			<div className='w-full pt-16 flex-1'>
				<Outlet />
			</div>
		</div>
	)
}

Image

제대로 채워주게 되었습니다!

This post is licensed under CC BY 4.0 by the author.