xtring.dev

[CSS] 무적의 레이아웃 세팅하기 Flex - 무엇이든 만들 수 있는 Flexbox 본문

Front-End/HTMLL & CSS

[CSS] 무적의 레이아웃 세팅하기 Flex - 무엇이든 만들 수 있는 Flexbox

xtring 2020. 3. 10. 01:40
반응형

CSS3

 

1. Introduce

Flexbox 기존의 웹 layout을 정의하는 방식 보다 세련되고 편한 방법을 제공합니다. Flexbox를 잘 알고 있다면 어떠한 Layout이라도 쉽고 빠르게 정의할 수 있습니다. 사이즈가 불명확하거나 동적인 경우에 효율적이며 쉽게 예측 가능하여 사용하기 편합니다.

 

웹 뿐만 아니라 React Native에서도 주로 사용되는 Position 방법이기 때문에 잘 알아두면 아주 쓸모가 있습니다!

 

 

기본적으로 웹에서는 div요소 즉 block 요소를 기본으로 수직정렬 상태를 가지고 있습니다. 이를 수평정렬하기 위해서는 

 

  1.  자식 요소(children)를 inlin-block으로 지정하고

  2. `float` 속성 지정을 사용합니다. 

 

.item { display: inline-block; /* or */ float: left; }

 

 

이때 각 자식 요소를 부모 요소 내에서 정렬하기 위해서는 각 자식 요소의 너비를 %로 지정하는 등 번거로운 처리가 필요합니다. 또한 자식 요소의 사이즈가 불명확하거나 동적으로 변화할 때에는 더욱 처리가 복잡해집니다.

 

 

Flexbox를 사용하여  부모 요소 내에서 균등 수평 정렬해보겠습다. 부모 요소에 아래에 다음과 같은 코드를 추가합니다.

.flex-container { display: flex; justify-content: space-around; }

 

자식 요소에 직접적인 너비를 지정하지 않더라도 이를 통해 평등한 spacing을 할 수 있습니다.

 

 

 

Flexbox의 장점

  • 1줄 코드 추가로 수평정렬이 가능
  • 요소의 상하좌우 정렬, 순서 변경이 간단함
  • 요소의 간격 조절이 간단
  • 서로 다른 height를 갖는 요소의 수평정렬 시, 간단히 상하중앙 정렬이 가능

 

 

 

2. Usage

 

Flexbox 레이아웃은

 

flex-container : 부모 요소

flex item: 자식 요소

 

로 구성됩니다.

 

flexbox를 사용하기 위해서 부모 요소의 display 속성에 flex를 지정합니다.

 

.flex-container { display: flex; }

 

부모 요소가 inline인 경우 inline-flex를 지정합니다.

 

.flex-container { display: inline-flex; }

 

flex 또는 inline-flex는 부모 요소에서 반드시 지정해야하는 유일한 속성이며 자식 요소는 자동적으로 flex item이 됩니다.

이를 통해 flex를 통한 Layout 정의를 시작할 수 있습니다!

 

 

 

3. Flexbox Container property

Flexbox의 아주 기본적이고 필수적인 속성(property)을 알아봅시다!

 

3.1 flex-direction

flex-direction 속성은 flex 컨테이너의 주축(main axis)방향을 설정합니다. 주축방향이란 Flexbox의 기본 설정 방향입니다. 이 주축을 따라서 자식들은 배치가 됩니다. 따라서 flex-direction: column이라면 주축은 상에서 하로 flex-dirction: row 라면 좌에서 우로 수평 배치됩니다. flex-direction 속성의 기본값이며 필수적입니다. flex-direction은 부모요소에서 지정합니다.

.flex-container { flex-direction: row; }

 

우에서 좌로(rtl) 수평 배치됩니다.

.flex-container { flex-direction: row-reverse; }

 

위에서 아래로 수직 배치됩니다.

.flex-container { flex-direction: column; }

 

아래에서 위로 수직 배치됩니다.

.flex-container { flex-direction: column-reverse; }

 

 

3.2 flex-wrap

flex-wrap 속성은 flex container의 복수 flex item을 1행으로 또는 복수행으로 배치합니다.

flex-wrap 속성은 flex container의 width보다 flex item들의 width의 합계가 더 큰 경우, 한줄로 표현할 것인지, 여러줄로 표현할 것인지를 지정합니다.

 

.flex-container { flex-wrap: nowrap; }

flex item을 개행하지 않고 1행으로 배치합니다. flex-wrap 속성의 default값입니다. 각 flex item의 폭은 flex container에 들어갈 수 있는 크기로 축소됩니다.

 

하지만 flex item들의 width의 합계가 flex 컨테이너의 width보다 큰 경우 flex 컨테이너를 넘치게 됩니다. 이때 overflow: auto;를 지정해주게 되면 가로 스크롤이 생기며 container에서 넘치지 않습니다.

 

.flex-container { flex-wrap: wrap; }

flex item들의 width의 합계가 flex 컨테이너의 width 보다 큰 경우, flex item을 복수행에 배치합니다. 기본적으로 좌에서 우로, 위에서 아래로 배치합니다.

 

.flex-container { flex-wrap: wrap-reverse; }

flex-wrap: wrap;과 동일하나 아래에서 위로 배치된다.(왼쪽에서 오른쪽, 아래에서 위로 채워나간다.)

 

3.3 flex-flox

flex-flow 속성은 flex-direction 속성과 flex-wrap 속성을 설정하기 위한 shorthand이다. default는 row nowrap이다.

.flex-container { flex-flow: <flex-direction> || <flex-wrap>; }

 

3.4 justify-content

flex container의 main axis(주축)를 기준으로 flex item을 수평 정렬합니다.

 

main start(좌측)를 기준으로 정렬합니다. justify-content 속성의 기본값입니다.

.flex-container { justify-content: flex-start; }

 

main end(우측)을 기준으로 정렬합니다.

.flex-container { justify-content: flex-end; }

 

flex container의 중앙으로 정렬합니다.

.flex-container { justify-content: center; }

 

첫번째와 마지막 flex item은 좌우 측면에 정렬되고 나머지 item들은 균등한 간격으로 정렬됩니다.

.flex-container { justify-content: space-between; }

 

모든 flex item은 균등한 간격으로 정렬됩니다.

.flex-container { justify-content: space-around; }

 

3.5 align-items

flex item을 flex container의 수직 방향(cross axis)으로 정렬합니다. 수직방향은 주축을 기준으로 수직을 의미합니다.

align-items 속성은 모든 flex item(하위 요소)에 적용됩니다.

 

모든 flex item은 flex container의 높이(cross start에서 cross end 까지의 높이)에 꽉찬 높이를 갖습니다. 이는 align-items 속성의 기본값입니다.(각 item이 container의 높이에 맞춰 채워집니다.)

.flex-container { align-items: strech; }

 

모든 flex item은 flex container의 cross start 기준으로 정렬됩니다.

.flex-container { align-items: flex-start; }

 

모든 flex item은 flex container의 cross end(세로 끝) 기준으로 정렬됩니다.

.flex-container { align-items: flex-end; }

 

모든 flex item은 flex container의 cross axis(세로 축)의 중앙 정렬됩니다.

.flex-container { align-items: center; }

 

모든 flex item은 flex container의 baseline을 기준으로 정렬됩니다.

.flex-container { align-items: baseline; }

 

3.6 align-content

flex container의 cross axis를 기준으로 flex item을 수직으로 정렬합니다.
참고로 justify-content 속성은 flex container의 main axis를 기준으로 flex item을 수평 정렬합니다.

 

모든 flex item은 flex item의 행 이후에 균등하게 분배된 공간에 정렬되어 배치됩니다. 이는 align-content의 속성의 기본값입니다.

.flex-container { align-content: strech; }

 

모든 flex item은 flex container의 cross start 기준으로 stack 정렬됩니다.(꽉꽉 붙여 정렬합니다.)

.flex-container { align-content: flex-start; }

 

모든 flex item은 flex container의 cross end 기준으로 stack 정렬됩니다.

flex-container { align-content: flex-end; }

 

모든 flex item은 flex container의 cross axis의 중앙에 stack 정렬됩니다.

.flex-container { align-content: center; }

 

첫번째 flex item의 행은 flex container의 상단에 마지막 flex item의 행은 flex container의 하단에 배치되며 나머지 행은 균등 분할된 공간에 배치 정렬됩니다.

.flex-container { align-content: space-between; }

 

모든 flex item은 균등 분할된 공간 내에 배치 정렬됩니다.

.flex-container { align-content: space-around; }

 

 

 

4. Felxbox item 속성

float, clear, vertical-align 속성은 flex item에 영향을 주지 않습니다.

 

4.1 order

flex item의 배치 순서를 지정합니다.
HTML 코드를 변경하지 않고 order 속성값을 지정하는 것으로 간단히 재배치할 수 있습니다. 기본 배치 순서는 flex container에 추가된 순서입니다. 기본값은 0입니다.

.flex-item { order: 정수값; }

정수값에 따른 순서를 부여한다. -1, -2,...도 가능합니다.

 

4.2 flex-grow

flex item의 너비에 대한 확대 인자(flex grow factor)를 지정합니다. 기본값은 0이고 음수값은 무효합니다.

.flex-item { flex-grow: 양의 정수값; }

모든 flex item이 동일한 flex-grow 속성을 가지면 모든 flex item은 동일한 너비를 갖습니다.(X:N 비율로 넓이를 가집니다.)
두번째 flex item의 flex-grow 속성값을 3으로 지정하면 다른 flex item보다 더 넓은 너비를 갖습니다.

 

4.3 flex-shrink

flex item의 너비에 대한 축소 인자(flex shrink factor)를 지정합니다. 기본값은 1이고 음수값은 무효합니다. 0을 지정하면 축소가 해제되어 원래의 너비를 유지합니다.

.flex-itme { flex-shrink: 양의 정수 값; }

기본적으로 모든 flex item은 축소된 상태로 지정(default: 1)하고 두번째 flex item만 축소를 해제(flex-shrink: 0;)하면 원래의 너비를 유지합니다.

 

4.4 flex-basis

flex item의 너비 기본값을 px, % 등의 단위로 지정합니다. 기본값은 auto입니다.

.flex-item { flex-basis: auto | <width>; }

 

4.5 flex

flex-grow, flex-shrink, flex-basis 속성의 shorthand입니다.

기본값은 0 1 auto입니다. W3C에서는 이 속성을 사용하는 것보다 개별적으로 기술하는 것을 추천하고 있습니다!

.flex-item { flex: none | auto | [ <flex-grow> <flex-shrink>? || <flex-basis> ]; }

 

4.6 align-self

align-items 속성(flex container 속성으로 flex item을 flex container의 수직방향(cross axis)으로 정렬합니다.) 보다 우선하여 개별 flex item을 정렬합니다.(default: auto)

.flex-item { align-self: auto | flex-start | flex-end | center | baseline | strech; }

 

 

Reference : https://poiemaweb.com/css3-flexbox
반응형
Comments