CSS 그리드에서 개별 요소의 수직 축 정렬
비슷한 방식으로
align-self 속성을 사용하여 요소를
수직 축으로 정렬할 수 있습니다.
예제를 통해 어떻게 작동하는지
살펴보겠습니다.
수직 축의 시작점 기준
첫 번째 요소를 수직 축의 시작점을 기준으로 정렬해 보겠습니다:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
</div>
#parent {
display: grid;
grid-template-columns: 100px 100px;
grid-template-rows: repeat(3, 1fr);
grid-gap: 10px;
padding: 10px;
border: 2px solid #696989;
height: 200px;
width: 400px;
}
#parent > div {
grid-gap: 10px;
padding: 10px;
box-sizing: border-box;
border: 1px solid #696989;
}
#elem1 {
align-self: start;
}
:
수직 축의 중앙 기준
첫 번째 요소를 수직 축의 중앙을 기준으로 정렬해 보겠습니다:
<div id="parent">
<div id="elem1">1</div>
<div>2</div>
<div>3</div>
<div>4</div>
</div>
#parent {
display: grid;
grid-template-columns: 100px 100px;
grid-template-rows: repeat(3, 1fr);
grid-gap: 10px;
padding: 10px;
border: 2px solid #696989;
height: 200px;
width: 400px;
}
#parent > div {
grid-gap: 10px;
padding: 10px;
box-sizing: border-box;
border: 1px solid #696989;
}
#elem1 {
align-self: center;
}
:
수직 축의 끝점 기준
그리드에서 첫 번째 요소를 수직 축의 끝점을 기준으로 정렬해 보겠습니다:
<div id="parent">
<div id="elem1">1</div>
<div>2</div>
<div>3</div>
<div>4</div>
</div>
#parent {
display: grid;
grid-template-columns: 100px 100px;
grid-template-rows: repeat(3, 1fr);
grid-gap: 10px;
padding: 10px;
border: 2px solid #696989;
height: 200px;
width: 400px;
}
#parent > div {
grid-gap: 10px;
padding: 10px;
box-sizing: border-box;
border: 1px solid #696989;
}
#elem1 {
align-self: end;
}
:
실습 문제
두 개의 열로 구성된 그리드를 만들고, 다섯 개의 요소를 배치하세요. 세 번째 요소를 그리드의 수직 축 시작점을 기준으로 정렬하세요.
이제 요소를 세 개의 열로 배치하고, 두 번째 요소를 그리드의 수직 축 중앙을 기준으로 정렬하세요.
이전 문제를 수정하여, 네 번째 요소와 다섯 번째 요소가 각각 수직 축의 끝점과 시작점을 기준으로 정렬되도록 하세요.