웹디자이너라면 꼭 알아야 할 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을 어떤방향으로 나열할지를 지정합니다.

css-tricks.com 참조

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

flex-wrap

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

css-tricks.com 참조

속성 설명
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들을 수평방향으로 정렬하는 방법을 지정합니다.

css-tricks.com 참조

속성 설명
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들을 수직방향으로 정렬하는 방법을 지정합니다.

css-tricks.com 참조

속성 설명
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들이 여러 줄로 표시될 때 수직방향으로 정렬하는 방법을 지정합니다.

css-tricks.com 참조

속성 설명
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의 순서를 지정합니다. 음수값도 사용할 수 있으며 숫자가 작을 수로 왼쪽에, 클수록 오른쪽에 위치합니다.

css-tricks.com 참조

.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 이며 음수는 사용하지 않습니다.

css-tricks.com 참조

.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의 속성과 동일하게 지정됩니다.

css-tricks.com 참조

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

참조한 사이트

Similar Posts

  • 구글스프레드시트에서 다른문서 참고하는 방법

    현재 스프레드시트계의 최강자는 마이크로소프트의 엑셀이라는 것은 부인할 수 없는 팩트입니다. 하지만 그런 엑셀의 빈틈을 비집고 들어가 특정한 면모에서 구글 스프레드시트가 점점 세력을 넒혀가고 있는 것도 사실입니다. MS 엑셀과 달리 웹브라우저만 있으면 언제 어디서든 무료로 사용할 수 있고 다른 사람들과도 쉽게 문서를 공유 할 수 있다는 큰 장점을 가지고 있는 구글 스프레드시트는 초창기에는 기능적인 면이 너무 […]

  • PhantomJS와 CasperJS 사용법

    프론트앤드 개발을 하거나 웹자동화에 관심이 있는 분이라면 PhantomJS와 CasperJS를 많이 들어봤을 것입니다. 저도 이번에 크롤링 공부를 하면서 알게되어 잊어버리지 않기위해 간단하게 정리를 하려고 합니다. PhantomJS (팬텀JS) 팬텀JS는 화면이 없는 브라우저라고 보면 됩니다. 화면이 없는 브라우저를 어따가 써먹지? 라고 생각할 수도 있겠지만 웹프로그램으로 웹자동화를 개발하기에는 더없이 편리한 기능을 제공하고 있습니다. 입력상자에 값을 입력한다던가 마우스로 버튼을 클릭한다던가 […]

  • 내 핸드백을 지키는 확실한 방법 Handbag dyenator

    소매치기로 부터 나의 핸드백을 지키는 확실한 제품이 나왔습니다. 아직 시제품이긴 하지만 상당히 아이디어가 좋습니다. 말레이시아의 업체인 Ash Be Nimble에서 개발을 하였고 제품명은 Handbag Dytonator이라고 합니다. 핸드백 엑세서리 형태로 판매가 된다고 하네요. 사용방법은 내 핸드백이 소매치기를 당했을 경우 핸드폰으로 Handbag Dytonator에게 폭발코드를 문자메시지를 보내면 Handbag Dytonator에 있는 SIM카드가 이것을 인식하여 약 5초 후에 폭발을 한다고 합니다. […]

  • Angular의 개발환경

    Angular의 개발환경 Angular를 개발하기위해서 일반적인 개발환경에 대해 포스팅 합니다. Nodejs 설치 타입스크립트 설치 Angular프로젝트 구성 Nodejs 설치 Angular의 기본적인 개발환경은 Nodejs입니다. Nodejs는 자바스크립트 기반으로 서버개발이 가능하고 NPM을 이용하여 패키지관리까지 가능하기 때문에 많이 사용하고 있습니다. 먼저 nodejs홈페이지에 접속하여 최신버전의 설치파일을 다운로드하여 설치 합니다. nodejs는 윈도우 환경 뿐만아니라 리눅스, macOS에서도 설치가 가능합니다. NPM으로 패키지 설치 Nodejs가 설치되었다면 […]

  • Angular의 개요

    Angular에 대한 세부적인 포스팅을 하기 전에 먼저 간단하게 개요를 정리 합니다. Angular란? 구글에서 만든 open-souce web application SPA(Single Page Application) 개발이 가능 다양한 플랫폼에 맞게 개발 가능 유지보수, 개발 속도 향상 (데이터 바인딩, 템플릿 등의 문법 제공 ) 아키텍쳐 Angular의 구성요소 Angular2를 구성하는 요소는 크게 4가지 입니다. 컴포넌트 (Component) 모듈 (Module) 서비스 (Service) 지시자 (Directive) […]

  • 맥북에서 크롬 브라우저사용 시 먹통 되는 문제 해결 방법

    맥에서 크롬브라우저를 사용하는 경우 처음에는 정상적으로 잘 구동되다가 어느 순간 브라우저가 먹통이 되는 경우가 있습니다. google이나 Naver에서 검색을 해도 결과물을 보여주지 않고 계속 우산만 돌리고 있는 경우가 있습니다. 이럴때는 덩달아 사파리 브라우저까지 멈춰버리는 데요.. 왜이럴까~~ 몇 일을 고민하고 인터넷 검색도 해보고 하다가 해결 방법을 찾은 듯 해서 포스팅을 합니다. 1달이 지난 지금까지 아직 이전처럼 먹통이 […]

답글 남기기

이메일 주소는 공개되지 않습니다. 필수 필드는 *로 표시됩니다