일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
- styling
- currying
- React Native
- ES6
- npm install
- Xcode
- GitLab
- rn
- HTML
- viewcontroller
- react-native
- Docker
- git
- github
- vscode
- npm
- xtring.log
- ReactNative
- Branch
- REACT
- ios
- Android
- JavaScript
- styled-components
- DevOps
- Swift
- commit
- nextJS
- shortcut
- js
- Today
- Total
xtring.dev
[CSS] 무적의 레이아웃 세팅하기 Flex - 무엇이든 만들 수 있는 Flexbox 본문
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; }
https://poiemaweb.com/css3-flexboxReference :
'Front-End > HTMLL & CSS' 카테고리의 다른 글
[HTML] <meta /> 그게 뭐야? - HTML 파헤치기 (0) | 2021.01.29 |
---|---|
[HTML] 시맨틱 웹(Semantic Web)이란? - HTML의 기본 중 기본 (0) | 2021.01.29 |
[HTML] HTML 글로벌 어트리뷰트(HTML Global Attribute)가 뭐야? - HTML 파헤치기 (0) | 2021.01.29 |
[HTML] HTML의 빈 요소(Empty Element)? - HTML 파헤치기 (0) | 2021.01.29 |