CSS 그리드에서 개별 요소의 수평 축 정렬
수평 축 정렬은
부모 요소뿐만 아니라 각 자식 요소에
개별적으로 설정할 수 있습니다.
이를 위해
justify-self 속성이
사용됩니다.
수평 축의 시작점 기준
첫 번째 요소를 수평 축의 시작점을 기준으로 정렬해 보겠습니다:
<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 {
justify-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 {
justify-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 {
justify-self: end;
}
:
실습 과제
두 개의 행에 다섯 개의 요소가 배치된 그리드를 생성하세요. 두 번째 요소를 수평 축의 시작점을 기준으로 정렬하세요.
이제 그리드 요소를 세 개의 행에 배치하고 세 번째 요소를 그리드의 수평 축 중앙을 기준으로 정렬하세요.
다섯 번째 요소가 수평 축의 끝점을 기준으로 정렬되도록 이전 과제를 수정하세요.