grid란?
css는 레이아웃과 스타일을 정의할 때 사용되는 언어입니다.
그 중 grid(그리드) 레이아웃의 끝판 왕이라고 할 수 있다.
Flex는 한 방향 레이아웃 시스템이고 (1차원)
Grid는 두 방향(가로-세로) 레이아웃 시스템 (2차원)
Grid 용어정리
- 그리드 컨테이너 (Grid Container) => display: grid를 적용하는, Grid의 전체 영역
- 그리드 아이템 (Grid Item) => Grid 컨테이너의 자식 요소
- 그리드 트랙 (Grid Track) => Grid의 행(Row) 또는 열(Column)
- 그리드 셀 (Grid Cell) => Grid의 한 칸을 가리키는 말
- 그리드 라인(Grid Line) => Grid 셀을 구분하는 선
- 그리드 번호(Grid Number) => Grid 라인의 각 번호
- 그리드 갭(Grid Gap) => Grid 셀 사이의 간격
- 그리드 영역(Grid Area) => Grid 라인으로 둘러싸인 사각형 영역으로, 그리드 셀의 집합
Grid 속성
grid의 속성들은 flex와 마찬가지로
1)컨테이너에 적용하는 속성
2)아이템에 적용하는 속성
으로 나뉘어져 있다.
1.컨테이너에 적용하는 속성
1) display: grid; => Grid 컨테이너에 display: grid;를 적용하는게 시작
2)grid-template-rows =>grid-template-rows는 행(row)의 배치
3) grid-template-columns => grid-template-columns는 열(column)의 배치
-fr은 fraction이다. 숫자 비율대로 트랙의 크기를 나눈다.
.container {
display:grid;
grid-template-columns: 200px 200px 500px;
/* grid-template-columns: 1fr 1fr 1fr */
/* grid-template-columns: repeat(3, 1fr) */
/* grid-template-columns: 200px 1fr */
/* grid-template-columns: 100px 200px auto */
grid-template-rows: 200px 200px 500px;
/* grid-template-rows: 1fr 1fr 1fr */
/* grid-template-rows: repeat(3, 1fr) */
/* grid-template-rows: 200px 1fr */
/* grid-template-rows: 100px 200px auto */
}
많이 쓰이는 함수
repeat(반복횟수, 반복값)
minmax (,) 최솟값과 최댓값을 지정할 수 있는 함수입니다.
minmax(100px, auto)의 의미는 최소한 100px, 최대는 자동으로(auto) 늘어나게
auto-fill과 auto-fit
auto-fill과 auto-fit은 column의 개수를 미리 정하지 않고 설정된 너비가 허용하는 한 최대한 셀
반응형
'개발 공부 > 웹개발' 카테고리의 다른 글
[CSS] Flex 아이템에 적용하는 속성들(1) (0) | 2021.08.03 |
---|---|
[CSS] FLEX -컨테이너에 적용하는 속성 (0) | 2021.08.02 |
오류 해결 - Warning: Can't perform a React state update on an unmounted component. (0) | 2021.07.19 |
동기(Synchronous)vs비동기(Asynchronous), block과 non-block 개념정리 (0) | 2021.06.24 |
[JavaScript] 배열 원소를 검색하여 없애거나 바꾸기 (0) | 2021.06.21 |
댓글