기본 콘텐츠로 건너뛰기

웹디자이너라면 꼭 알아야 할 Flexbox Layout

웹디자인을 하면서 레이아웃을 잡는 방법에 대해서 시대별로 많은 변화가 있었습니다. Web이 나오기 시작한 초창기에는 Table을 이용하여 화면의 레이아웃을 잡았고 웹표준, 웹접근성이 이슈화 되면서 시멘틱한 마크업이 대세가 되면서 CSS의 DIV를 이용한 방법으로 레이아웃을 잡았습니다.
CSS3로 버전업이 되면서 레이아웃 구현애 대한 방법으로 Flexbox가 탄생하게 되었고 2017년 현재 레이아웃을 편리하게 구현하기 위해서는 Flexbox를 사용하여 구현하는 것이 최선이라 할 수 있습니다. 그래서 웹디자이너Frontend 개발자라면 꼭 이해를 하고 넘어가야 하는 요소입니다.

Flexbox의 브라우저별 지원 현황

브라우저별 Flex 지원은 현재 대부분의 브라우저가 지원하고 있다고 보면 되고 Internet Explorer사파리 브라우저 같은 경우는 prefix를 사용해서 적용해야 합니다.

  • Internet Explorer : IE10
  • 파이어폭스 : FF28.0
  • 사파리 : 6.1
  • 크롬 : 29.0
  • 오페라 : 12.10

Flexbox의 특징

W3C에서의 정식 명칭은 CSS Flexible Box Layout Module이라고 정의 하고 있으며 이름처럼 레이아웃을 유연하게 구현하는 모듈이라고 보면 됩니다. 예전에 레이아웃을 구현하기 위해서는 정식 사용법이 아닌 편볍처럼 복잡하게 구현을 했어야 했던것에 반해 Flexbox는 쉽게 레이아웃을 구현할 수 있습니다.

Flexbox

FlexboxContainerItem으로 구성됩니다. Flex의 선언은 Container의 CSS에 display: flex로 선언을 해 줍니다.

IE10 인 경우는 flex 대신 display: flexbox 로 지정
.container { display: flex }
<div class="container">
  <div class="item"></div>
  <div class="item"></div>
  <div class="item"></div>
</div>

Container 설정

Flex의 설정은 대부분 Container쪽에 지정을 합니다. Item에 지정하는 경우는 Item별로 개별지정할 때 주로 사용됩니다.

flex-direction

Container 안에 있는 Item을 어떤방향으로 나열할지를 지정합니다.

속성 설명
row Item을 수평방향으로 좌에서 우로 나열함 (기본값)
row-reverse Item을 수평방향으로 우에서 좌로 나열함
column Item을 수직방향으로 상에서 하로 나열함
column-reverse Item을 수직방향으로 상에서 하로 나열함
.container { 
    display: flex;
    flex-direction: row;
}

flex-wrap

Container 안에 있는 Item이 Container를 넘어설 때 줄바꿈을 할지 한 줄로 표현할지에 대해 지정합니다.

img

속성 설명
nowrap Item을 줄바꿈하지 않고 한줄에 표시함 (기본값)
wrap Item이 Container을 넘어설 경우 다음줄에 줄바꿈하여 표시함
wrap-reverse Item이 Container을 넘어설 경우 역방향으로 줄바꿈하여 표시함
.container { 
    display: flex;
    flex-wrap: nowrap;
}

flex-flow

flex-directionflex-wrapflex-flow로 한 줄에 지정할 수 있습니다. 첫번째 요소는 flex-direction 의 설정값을, 두번째 요소는 flex-wrap의 설정값을 지정하면 됩니다.

.container { 
    display: flex;
    flex-flow: row wrap;
}

justify-content

Container안에 있는 Item들을 수평방향으로 정렬하는 방법을 지정합니다.

img

속성 설명
flex-start Container안에 있는 Item들을 왼쪽으로 정렬함 (기본값)
flex-end Container안에 있는 Item들을 오른쪽으로 정렬함
center Container안에 있는 Item들을 수평방향의 중앙에 정렬함
space-between Container안에 있는 Item들을 일단 양쪽끝에 붙히고 나머지 Item들을 일정간격으로 정렬함
space-around Container안에 있는 Item들을 좌우 각각 일정간격으로 정렬함
.container { 
    display: flex;
    flex-flow: row wrap;
    justify-content: flex-start;
}

align-items

Container안에 있는 Item들을 수직방향으로 정렬하는 방법을 지정합니다.

img

속성 설명
flex-start Container안에 있는 Item들을 상단에 정렬함 (기본값)
flex-end Container안에 있는 Item들을 하단에 정렬함
center Container안에 있는 Item들을 수직방향의 중앙에 정렬함
baseline Container안에 있는 Item들을 baseline으로 정렬함
stretch Container안에 있는 Item들을 Container의 높이와 동일하게 상하로 늘려서 상단과 하단에 정렬함
.container { 
    display: flex;
    flex-flow: row nowrap;
    align-items:flex-start;
}

align-content

Container안에 있는 Item들이 여러 줄로 표시될 때 수직방향으로 정렬하는 방법을 지정합니다.

img

속성 설명
flex-start Container안에 있는 여러 줄의 Item들을 모두 상단에 정렬함 (기본값)
flex-end Container안에 있는 여러 줄의 Item들을 모두 하단에 정렬함
center Container안에 있는 여러 줄의 Item들을 모두 수직방향의 중앙에 정렬함
space-between Container안에 있는 Item들의 줄을 일단 상단과 하단 끝에 붙히고 나머지 Item들을 일정간격으로 수직방향으로 정렬함
space-around Container안에 있는 Item들의 줄을 일정간격으로 수직방향으로 정렬함
stretch Container안에 있는 Item들의 줄의 높이를 Container의 높이와 맞게 늘려서 정렬함

Item 설정

위에는 Container에 대한 설정이라면 이제는 그 안에 있는 Item들에 대한 설정으로 Item의 넓이, 순서 등 Item의 개별적인 속성에 대한 설정 방법입니다.

order

Container안에서 Item의 순서를 지정합니다. 음수값도 사용할 수 있으며 숫자가 작을 수로 왼쪽에, 클수록 오른쪽에 위치합니다.

img

.container .item-1 { order: -1; }
.container .item-2 { order: 0; }
.container .item-3 { order: 1; }
.container .item-4 { order: 2; }

flex-grow

각 Item의 넓이를 배수로 지정을 합니다. item-1flex-grow1이고 item-2flex-grow2라면 item-2item-1보다 2배가 크게 됩니다. 기본값은 0 이며 음수는 사용하지 않습니다.

img

.container .item-1 { flex-grow: 1; }
.container .item-2 { flex-grow: 2; }
.container .item-3 { flex-grow: 0; }
.container .item-4 { flex-grow: 0; }

flex-shrink

flex-grow와 반대로 각 Item의 넓이를 배수로 빼집니다. item-1flex-grow1이고 item-2flex-grow2라면 item-2item-1보다 2배가 작게 됩니다. 기본값은 1 이며 음수는 사용하지 않습니다.

.container .item-1 { flex-shrink: 1; }
.container .item-2 { flex-shrink: 2; }
.container .item-3 { flex-shrink: 0; }
.container .item-4 { flex-shrink: 0; }

flex-basis

Item의 기본 크기값을 지정합니다.

.container .item-1 { flex-basis: 200px; }

flex

flex-growflex-shrink, flex-basisflex로 한 줄에 지정할 수 있습니다. 첫번째 요소는 flex-grow 의 설정값을, 두번째 요소는 flex-shrink의 설정값을, 세번째 요소는 flex-basis의 설정값을 지정하면 됩니다.
기본값은 flex: 0 1 auto 입니다.

.container .item-1 { flex: 0 1 200px; }

align-self

지정된 Item의 독자적인 수직방향 정렬을 지정합니다. align-items의 속성과 동일하게 지정됩니다.

img

속성 설명
flex-start Container안에 있는 지정된 Item을 상단에 정렬함
flex-end Container안에 있는 지정된 Item을 하단에 정렬함
center Container안에 있는 지정된 Item을 수직방향의 중앙에 정렬함
baseline Container안에 있는 지정된 Item을 baseline으로 정렬함
stretch Container안에 있는 지정된 Item을 Container의 높이와 동일하게 상하로 늘려서 상단과 하단에 정렬함

참조한 사이트

댓글

이 블로그의 인기 게시물

CSS에서 ellipsis('...')를 처리하는 방법

이번에 ellipsis에 대해 정리해 보도록 하겠습니다. 보통 게시판 리스트의 제목부분이 길어질 경우 php나 jsp등의 프로그램단에서 일정 글자수 이상이 되는 것에 대해 '...'으로 마무리 하는 경우가 많은데요.. 이것을 프로그램이 아닌 CSS만 가지고도 처리할 수 가 있습니다. 한줄라인 글자수 제한 한줄 라인 글자수 를 제한하는 방법은 아래와 같습니다. <div class="txt_line">통영의 신흥보물 강구안의 동쪽벼랑인 동피랑의 벽화마을을 다녀왔다</div> .txt_line { width:70px; padding:0 5px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; } Block레벨 테그에서만 적용됨. overflow:hidden : 넓이가 70px를 넒어서는 내용에 대해서는 보이지 않게 처리함 text-overflow:ellipsis : 글자가 넓이 70px를 넘을 경우 생략부호를 표시함 white-space:nowrap : 공백문자가 있는 경우 줄바꿈하지 않고 한줄로 나오게 처리함 (\A로 줄바꿈가능) 멀티라인 글자수 제한 멀티라인에 대해서 글자수를 제한하는 방법은 아래와 같습니다. <p class="txt_post">통영의 신흥보물 강구안의 동쪽벼랑인 동피랑의 벽화마을을 다녀왔다.&nbsp; 비도 추적추적 내리고 일정상 늦으막해서 그런지 사람이 많지는 않았다. 덕분에 보통때는 한참을 기다려야 겨우 날개달린 사진을 찍을 수 있었을 텐데, 이번에는 바로 천사날개를 달고 사진을 찍을 수 있는 행운까지 얻었다. 이번이 동피랑 벽화마을 방문 3번째인데 예전에 왔을때에 비해서 벽화가 많이 바뀌어 있었다</p> .txt_post { overflow: hidden; text-ove...

Google 스프레드시트로 구글캘린더에 일정 연동하는 방법

저는 구글 제품을 많이 사용하는 편입니다. 제 주력 캘린더도 Google 캘린더 고요. 이번에 모임의 임원을 맡게 되면서 회원들의 생일을 캘린더에 등록해야 할 일이 생겼어요. 그냥 하나하나 등록을 하는 도중 "내가 지금 뭐하고 있나.." 라는 자괴감이 들기 시작했어요. 구글 시트에 있는 날짜 정보(생일)을 한 번에 쉽게 일괄 등록할 수는 없을까라는 생각이 뇌리를 스쳤습니다. 그래서 찾아봤더니.. 약간의 매크로 프로그램을 작성하면 가능할 것 같더라고요. 그래서 열심히 개발을 해봤습니다. 1시간이면 등록할 것을 8시간 걸려서 프로그램을 짜 봤어요. 결과적으로는 더 비효율적이었네요. ㅠㅠ 그러나... 나에게는 비효율 적이었지만 이코드를 공개하면 다른 사람에게는 큰 도움이 될 수 있겠구나 생각을 하고 코드를 공개해 보려고 합니다. 준비물 준비물은 Google 스프레드시트, Google 캘린더만 있으면 돼요. 당연히 무료고요. Google 캘린더 먼저 Google 캘린더를 만들거나 사용하고 있는 캘린더를 준비합니다. 적용하기 원하는 캘린더의 우측의 ... 를 클릭하고 설정 및 공유 를 선택합니다. 캘린더 ID를 잘 기억해 놓습니다. 나중에 이 ID를 활용할 예정입니다. Google 스프레드시트 회원생일 스프래드시트 공유 Google 스프레드시트로 명단과 생일을 작성합니다. ▲ 위와 같이 작성을 하면 되고 중요한 사항은.. 생년월일 이 구글 시트의 날짜 형식에 맞아야 합니다. 그리고 갤린더등록 , 캘린더상태 의 항목은 필수로 있어야 합니다. 캘린더등록 : 캘린더에 등록할지 제거할지를 표시 (ADD / DEL) 캘린더상태 : 현재 캘린더에 해당 항목이 적용되었는지 확인 (Y / ' ') 매크로 프로그램 작성하기 기본적인 준비는 끝났습니다. 이제부터 Apps Script를 제작하고 트리거를 등록하면 됩니다. Apps Script 작성하기 Apps Script 는 구글 제품에 대...

Google캘린더(달력)에 대한민국 휴일 표시하기

구글 캘린더에 대한민국 휴일을 표시하는 설정에 대해서 소개합니다. 네이버 달력이라면 그냥 기본으로 나오겠지만 구글캘린더의 경우는 별도의 설정을 해 주어야 합니다. 휴일의 표시는 각 나라의 휴일을 구글에서 미리 작성해 놓은 것을 내 캘린더에 불러와 적용하는 방식으로 되어 있습니다. 대한민국 공유일 표시하기 먼저 설정화면으로 이동합니다. 캘린더 화면의 우측상단의 설정 아이콘을 클릭합니다. 메뉴 중 설정 을 클릭합니다. 설정화면 중 좌측 메뉴에서 캘린더 추가 메뉴를 선택합니다. 관심분야와 관련된 캘린더를 선택합니다. 지역 공휴일의 모두 둘러보기 를 선택하면 각나라의 휴일을 선택할 수 있습니다. 우리는 대한민국의 휴일 을 선택합니다. 캘린더에서 공휴일 보기 대한민국 휴일에 대한 설정을 했다면 이제 보기 좋게 표시하면 됩니다. 설정을 정상적으로 했다면 좌측메뉴에 대한민국의 휴일 이라는 캘린더가 보입니다. 캘린더명의 우측끝에 더보기 아이콘 을 선택합니다. 색상을 빨간색으로 선택합니다. (보통 공휴일은 빨간색이므로.. ㅎ) 그러면 캘린더에 휴일의 명칭이 빨간색 으로 표시되게 됩니다. 감사합니다.