Home GRID-TEMPLATE
Post
Cancel

GRID-TEMPLATE

1. GRID TEMPLATE

이번에는 훨씬더 직관적이고 더 쉽게 GRID를 만들어보도록 하자. 바로 GRID-TEMPLATE 라는 PROPERTY 를 사용해서 말이다. 그리고 GRID의 각 행과 열에 이름을 붙여 세부적으로 MODIFY 할 수 도 있다. 또한 특정 행과 열이 어디부터 어디까지 이어지는지도 정할 수 있다. 먼저 HTML 부터 만들자.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width = device-width, initial-scale = 1.0" />
    <link rel="stylesheet" href="grid2.css" />
    <title>SCSS CLASS WITH NICO</title>
  </head>
  <body>
    <div class="grid">
      <div class="header">header</div>
      <div class="content">content</div>
      <div class="nav">nav</div>
      <div class="footer">footer</div>
    </div>
  </body>
</html>

그리고 CSS도!!

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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
.grid {
  display: grid;
  /* fraction(fr): 
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(4, 1fr);  1fr 은 1 fraction 즉 화면의 크기가 얼마나 작든 크든 동일한 비율로 한 조각을 차지한다는 뜻이다. 화면의 크기에 따라 유연하게 사이즈가 달라지기 때문에 매우 유용하다.*/

  /*naming:
    grid-template-columns: [first] 100px [second] 100px [third] 100px [forth] 100px [fifth];
    grid-template-rows: repeat(4,100px [line]);
     columns 네이밍과 rows 네이밍이 같은 말이다. */

  height: 50vh; /*화면의 반을 차지한다. 높이를 설정해주지 않으면 item이 늘어날 공간이 없으므로 유의해주자 */

  grid-template:
    [h-s] "header header header header" 1fr [h-e]
    [c-s] "content content content nav" 2fr [c-e]
    [f-s] "footer footer footer footer" 1fr [c-e] / 1fr 1fr 1fr 1fr;
  /* grid-template 를 쓰면 높이까지 한꺼번에 설정할 수 있기 때문에, 
    그리고 각각의 상자가 얼마만큼 차지하는지 까지 세부조정할 수 있기 때문에 훨씬 쉽고 빠른 작업이 가능함.
    그리고 [] 안에 네이밍 까지 가능하다. 거의 그림을 그린것 처럼 볼 수 있어서 직관적이기도 하다. */
  gap: 10px;
}

.header {
  background-color: grey;
  grid-column: 1 / 5;
  grid-area: header;
  /*grid-template를 쓰면 반드시 grid-area를 child 내부에 명시해줘야 grid-template가 적용이된다.
   grid-column:  first / fifth; 이런식으로 네이밍한걸 써먹을 수 있다. */
}

.content {
  background-color: blue;
  /* grid-column-start: 1;
    grid-column-end: 4;
    grid-row-start: 2;
    grid-row-end: 4; 
    grid-column: 1 / -2;
    grid-row: span 2;*/
  grid-area: content;
}
/*이런식으로 행과 열의 어느위치에서 시작해서 끝날지 결정할 수 있다. */

/* 아님 더 간략화시킬 수 있다. a/b 라고 하면 a에서 부터 b까지란 뜻이고, span 숫자 하면 숫자만큼의 공간을 차지한다는 뜻이다 */

/* 더 간단한 방법이 있다. row-start + column-start + row-end + column-end = grid-area rs / cs / re/ ce */

.nav {
  background-color: brown;
  grid-area: nav;
}

.footer {
  background-color: burlywood;
  grid-area: footer;
}
/* 아무리 변화를 줘도  안바뀌길래 먼가 했더니 typo였다. typo가 뜨면 빨간줄로 표시된다. 잘 살펴보자 */

결과

template

그럼 이렇게 짠 하고 나타난다. 화면의 반만 사용된걸 볼 수 있다.

This post is licensed under CC BY 4.0 by the author.