-
[HTML/CSS] CSS의 수평 수직 정렬구조 (float / flex)웹 개발/HTML & CSS 2021. 4. 8. 17:18반응형
flutter에서는 수직을 column 위젯으로, 수평을 row 위젯으로 정의해 레이아웃을 만들었다.
css에서는 flutter와 달리 float, display 등 레이아웃을 위한 다양한 방법이 있었는데
그 중 display property!
대부분의 요소들이 수직으로 display되는 block 구조이고
inline, inline-block처럼 수평으로 display되는 구조도 있다.
하지만 block 구조는 계속해서 수직으로 쌓이고 inline은 수평으로 쌓여서
내가 원할 때 줄바꿈을 어떻게 해야할지, 다른 방법은 있는지 고민이 많았다.
그래서 정리해보았다!
float 속성을 이용한 수평 정렬 - clear property
float을 이용해 수평구조를 만든 후 float의 적용을 없애고 수직으로 넣고 싶은 요소가 있을 경우
해당 요소의 css에 clear property를 추가해야한다.
clear property는 float가 적용되지 않게 한다.
(예시) 수평 요소들에 left 적용
<div class = "header"> <img class = "logo" src = ""> <ul class = "nav"> <li><a href="#feed" class="active">피드</a></li> <li><a href="#story">스토리</a></li> <li><a href="#skin">스킨</a></li> <li><a href="#community">포럼</a></li> </ul> <img class = "alarm_img" src = "https://image.flaticon.com/icons/png/512/51/51839.png"> <img class= "profile_img" src = "https://i1.daumcdn.net/thumb/C100x100/?scode=mtistory2&fname=https%3A%2F%2Ft1.daumcdn.net%2Ftistory_admin%2Fblog%2Fadmin%2Fprofile_default_00.png"> </div> <div class = "content"> ... </div>
1) 수평 요소들의 끝에 clear-element 를 추가하여 clear : both 적용
... <img class = "alarm_img" src = "https://image.flaticon.com/icons/png/512/51/51839.png"> <img class= "profile_img" src = "https://i1.daumcdn.net/thumb/C100x100/?scode=mtistory2&fname=https%3A%2F%2Ft1.daumcdn.net%2Ftistory_admin%2Fblog%2Fadmin%2Fprofile_default_00.png"> <div class="clear-element"></div> </div>
.logo { float: left; padding: 14px 16px; width: 24px; height: 24px; } .nav{ float: left; list-style-type : none; margin: 0; padding: 0; } .clear-element { clear: both; /* or left */ }
2) 수평이 될 요소(float 적용된) 들을 clearfix로 감싸 clear를 적용하는 방법 (권장)
<div class="clearfix"> ... </div>
.clearfix::after { content: ""; clear: both; display: block; }
Flexible Box를 이용한 수평정렬
해당 요소는 flutter와 비슷했다.
flex에는 Container개념과 Container 내부에 들어갈 Items 개념으로 나뉘는데
각각의 개념에 적용되는 요소들이 달랐다.
Container
1) display (container간의 정렬)
- 수직 (block)
display: flex
- 수평 (inline)
display : inline-flex
Item
1) flex-flow (item 간의 정렬)
flex-direction : row //왼쪽에서 오른쪽 flex-direction : row-reverse flex-direction : column //위에서 아래 flex-direction : column-reverse
flex-wrap : nowrap //한 줄 flex-wrap : wrap // 여러 줄
- 주축 (main-axis) 기준 정렬방법
justify-content : flex-start; //시작점에 정렬 justify-content : flex-end; // 끝점에 정렬 justify-content : center; //가운데 정렬 justify-content : space-between; // 시작점 끝점에 정렬하고 그 사이 여백 균등하게 정렬 justify-content : space-around; //균등한 여백 포함
- 교차 축(cross-axis) 기준 정렬방법
align-content는 여러줄일 때 , align - item은 한 줄 일때
align-content: stretch; //여백없이 늘리기 align-content : flex-start; align-content : flex-end; align-content : center; align-content : space-around;
align-items: stretch; align-items : flex-start; align-items : flex-end; align-items : center; align-items : baseline; //문자기준선에 맞춤
참고
(아래의 링크에 가면 각 요소별 이미지를 볼 수 있습니다)
반응형'웹 개발 > HTML & CSS' 카테고리의 다른 글
[CSS] CSS를 대체할 CSS in CSS와 CSS in JS에 대해 알아보자 (CSS Module , SCSS 등) (0) 2021.05.11 [HTML/CSS] Tstory - story 페이지 클론 (0) 2021.04.11 [HTML/CSS] CSS 기본 레이아웃 요소 정리 (0) 2021.02.17 [CSS] CSS 속성 예시 (0) 2020.06.30 [CSS] CSS 기본 문법 (0) 2020.06.23