CSS에서의 Grid 시스템 이란?
이전 포스팅에서도 알려드렸던 내용을
잠깐 복습하고 가도록 합니다.
Flex와 달리 Grid는
각 셀을 이루는 가로축 세로축
가이드라인(=Grid)를 기준으로 합니다.
양수로 카운트 할 때는 좌에서 우로
음수로 카운트 할 때는 우에서 좌로
Grid Number를 지정할 수 있다고 했습니다.
data:image/s3,"s3://crabby-images/39fbd/39fbda338a41fe3270d027c534bf14fd34abb209" alt=""
그리고 Grid의 시작은
부모(Container) 요소에서 display: grid;를
주는 것으로 시작합니다.
그리고 grid-template-columns와
grid-template-rows를 이용해서
바둑판 모양의 격자를 만들고 시작하게 된다고 했죠?
#garden {
display: grid;
grid-template-columns: 20% 20% 20% 20% 20%;
grid-template-rows: 20% 20% 20% 20% 20%;
}
자, 그러면 이 상의 내용을
머릿속에 잘 남겨 두시고
나머지 문제들을 함께 풀어보시죠!
문제 15
grid-column과 grid-row를
span과 함께 사용하는 문제입니다.
data:image/s3,"s3://crabby-images/5920f/5920ffd16e789497f249464fbb62f53ec67bd7b5" alt=""
start / end 두 개는 슬래시로 구분한다!
이전 포스팅에서의 내용을 기억해봅시다.
data:image/s3,"s3://crabby-images/45df3/45df3c157088b439f689635d56c41c0b7561f84f" alt=""
#water {
grid-column: 2 / span 4;
grid-row: 1 / span 5;
}
칼럼과 로우의 시작점(start)를 지정하고
span으로 확장하였습니다.
물론 문제풀이가 아니라면
end를 직접 지정해줘도 동일하게 동작합니다.
#water {
grid-column: 2 / 6;
grid-row: 1 / 6;
}
문제 16
grid-column과 grid-row를 축약할 수 있는
grid-area에 대해서 알려주는 문제입니다.
역시 구분을 슬래시(/)로 할 수 있는데요,
순서는 row-column-row-column 인데
로칼로칼로 기억하면 편리합니다.
data:image/s3,"s3://crabby-images/21b30/21b307f04728555daad1a129edf702cacc7ef5f9" alt=""
grid-area는 grid-column + grid-row의 축약형
data:image/s3,"s3://crabby-images/1f90e/1f90e5b5a7f934be5c7881c4493f360dd9b7144c" alt=""
#water {
grid-area: 1 / 2 / 4 / 6;
}
grid-area의 표현방식은
마치 CSS의 margin이나 padding 단축형과
비스무리한 형태를 띈다고 보면 되겠습니다.
문제 17
grid-area를 2개 겹쳐서 사용하는 방식을
응용학습하는 문제입니다.
data:image/s3,"s3://crabby-images/d900b/d900b97bea2ca9b268ea6823ee43b9110ec8aa2b" alt=""
먼저 #water-1에는
grid-area가 적용되어 있음을 참고하고
#water-2에 grid-area를 적용해보면,
data:image/s3,"s3://crabby-images/8bc4b/8bc4b4e89a2aa9d3ef67abf9b56583baf4f3d267" alt=""
#water {
grid-area: 2 / 3 / 5 / 6;
}
중요한 것은
로우-스타트 / 칼럼-스타트 / 로우-엔드 / 칼럼-엔드
순서로 적용한다는 것!
문제 18
Grid 또한 Flex처럼
Orer 속성을 사용해서
배치 순서를 지정해줄 수 있습니다.
data:image/s3,"s3://crabby-images/3d376/3d376fa9b03c2bc4fff16d1f6dabd9fd5c820e71" alt=""
poison에 order를 주면 되겠네요.
data:image/s3,"s3://crabby-images/fc02f/fc02f368820eda2083c79a17af64561405f567f1" alt=""
#poison {
order: 1;
}
문제 19
역시 order를 활용하는 문제입니다.
data:image/s3,"s3://crabby-images/a4daf/a4daf5d8a7471256c20dce8159d85f797cc9aa71" alt=""
특별히 order를 지정하지 않으면
디폴트 값은 0입니다.
0보다 앞선 자리에 배치하려면?
data:image/s3,"s3://crabby-images/c6d00/c6d00158f9a7b6dd55dea7f8cb48342cf70034be" alt=""
#poison {
order: -1;
}
문제 20
이번 문제부터는 부모 요소 즉,
Container를 설정하는 문제입니다.
사실, 전체적인 레이아웃을 설정하는 것이라
자식 요소를 배치하는 것보다는
초반에 grid를 익히는데 살짝 헷갈릴 수 있겠습니다.
grid-template-columns를 다루는 문제입니다.
(※ 복수형으로 끝에 s가 붙습니다!)
data:image/s3,"s3://crabby-images/0cdeb/0cdebf1134a9df9a1cd2cba97197cc6636b22dde" alt=""
칼럼, 로우 각각 5개 요소인데,
columns를 2개로 만들어보면 해결이 될듯 보입니다.
data:image/s3,"s3://crabby-images/d6cb1/d6cb18df1a14e881745da469c186aee175129ce1" alt=""
#garden {
display: grid;
grid-template-columns: 50% 50%;
grid-template-rows: 20% 20% 20% 20% 20%;
}
생각보다 간단하게 풀리는군요!
문제 21
반복되는 값들을 간편하게 설정할 수 있는
repeat()에 대한 문제입니다.
(그리고 은근 슬쩍 %를 사용할 수 있음을 보여주네요.)
data:image/s3,"s3://crabby-images/1fa5b/1fa5b5ffb1ec0969c514e9889e472923ff1a7093" alt=""
repeat()는 다른 언어들에서도 많이 사용하는
내장 함수 형태를 빌어온 듯 보여집니다.^^
data:image/s3,"s3://crabby-images/6cbff/6cbff9e1a8583b35e2cd1a2561de48386dc399de" alt=""
#garden {
display: grid;
grid-template-columns: repeat(8, 12.5%);
grid-template-rows: 20% 20% 20% 20% 20%;
}
문제 22
columns 설정에 px, em, % 등을
편의에 맞게 사용할 수 있음을 보여주는 문제입니다.
data:image/s3,"s3://crabby-images/d6092/d60921d001a8ede4b8be1affd157c11af8611a4a" alt=""
문제 속에 답이...ㅋㅋ
data:image/s3,"s3://crabby-images/8a421/8a42168bace890b0213f24ed315ff9fb6b3083f6" alt=""
#garden {
display: grid;
grid-template-columns: 100px 3em 40%;
grid-template-rows: 20% 20% 20% 20% 20%;
}
문제 23
grid의 fr 단위 사용을 학습하는 문제.
fr은 fraction(분수, 등분)
즉, 등분의 개념으로 레이아웃을 설정합니다.
data:image/s3,"s3://crabby-images/68ef8/68ef8199df2d62a6b4f58bc0ec059259c6b27be4" alt=""
정답은, 몇 대 몇?
data:image/s3,"s3://crabby-images/eccec/eccecbba66a42ec209a001953760386976e0b8ac" alt=""
#garden {
display: grid;
grid-template-columns: 1fr 5fr;
grid-template-rows: 20% 20% 20% 20% 20%;
}
문제 24
수치로 딱딱 정해진 나머지 공간을
fr(fraction, 프랙션)을 이용하여 등분할 수 있음을
알려주는 문제입니다.
data:image/s3,"s3://crabby-images/54ed6/54ed66b2129b46c6821a51ce34d0848e6bed7feb" alt=""
좌우 50px은 딱딱 정해준 숫자
남는 공간을 3등분 한다면?
data:image/s3,"s3://crabby-images/ce5da/ce5da8e114ffd5a339cf5714d675f7d41709829f" alt=""
#garden {
display: grid;
grid-template-columns: 50px 1fr 1fr 1fr 50px;
grid-template-rows: 20% 20% 20% 20% 20%;
}
문제 25
px(pixel) 단위와 fr(fraction) 단위를
함께 사용하는 문제입니다.
data:image/s3,"s3://crabby-images/71cc4/71cc413a15394b10bc271909cc60b3c15a6420d4" alt=""
살짝 복잡한듯 보이지만 뭐 이 정도는~
data:image/s3,"s3://crabby-images/3660d/3660d2896187984caac01ba9d9feffe20ecc3e28" alt=""
#garden {
display: grid;
grid-template-columns: 75px 3fr 2fr;
grid-template-rows: 20% 20% 20% 20% 20%;
}
문제 26
grid-template-columns에 적용가능한 건
grid-template-rows에도 적용이 가능하겠죠?
data:image/s3,"s3://crabby-images/88add/88addcda83952924f8f4d9cd7006240e90293485" alt=""
더 이상의 자세한 설명은 생략한다!
data:image/s3,"s3://crabby-images/39588/3958841091932a2a601c1082264f1349061cd95a" alt=""
#garden {
display: grid;
grid-template-columns: 20% 20% 20% 20% 20%;
grid-template-rows: repeat(4, 12.5px) 1fr
}
문제 27
grid-template 축약형에 대한 학습입니다.
CSS는 반복적인 사용이 많기 때문에
축약형이 항상 준비되어 있는 경우가 많습니다.
data:image/s3,"s3://crabby-images/e778d/e778d6df82317c955fba2d1034bd84a60023f4a0" alt=""
grid-template = grid-template-columns + grid-template-rows
data:image/s3,"s3://crabby-images/a4284/a4284adc05b1484a489b7e7f49812c9e8466d47d" alt=""
#garden {
display: grid;
grid-template: 60% / 200px;
}
문제 28
대망의 마지막 문제입니다! 오오옷!!
grid-template 축약형으로 클리어해봅시다!
data:image/s3,"s3://crabby-images/26083/26083aff0024ec2d901c0b6cf9e0ac16b7aea873" alt=""
끝판왕 치고는 쉬운 편입니다.
data:image/s3,"s3://crabby-images/e3923/e392338b5dfe13c1c0c6d8a33696ed8d04eff474" alt=""
#garden {
display: grid;
grid-template: 1fr 50px / 20% 1fr;
}
이로써 Grid 28 문제를
모두 클리어했습니다!
짝짝짝!!
엔딩화면
Flex Froggy는 없었지만
Grid Garden에는 엔딩이 준비되어 있습니다.
역시 게임에는 엔딩이 있어야 제맛!
data:image/s3,"s3://crabby-images/4a8eb/4a8eb6c56727a3bfc34fb232167337a3453f57c0" alt=""
배지를 보상으로 주면서
다음 유료 게임들도 참여를 하도록
슬쩍 유도를 하는 마케팅?^^
아무튼 이렇게 Grid에 대한
문제풀이 대장정도 끝났습니다!
코딩에 관련한 내용으로
이렇게 게임을 만드는 것도
상당히 재미있는 작업인 것 같습니다.
시간이 흘러 Flex나 Grid가
가물가물해지는 미래의 나를 만나게 될 때
가볍게 한번 더 도전해보면 좋겠습니다.
모두 모두 즐코딩 하세요!
KINcoding !
'HTML+CSS' 카테고리의 다른 글
부트스트랩 Layout의 시작 - BreakPoints, Container, Grid (0) | 2022.12.24 |
---|---|
Bootstrap을 이용한 반응형 Article 만들기 기초 (0) | 2022.12.11 |
재미있게 Grid 공부하기 - Grid Garden 문제풀이 1~14 (0) | 2022.12.07 |
반응형으로 Youtube 영상 삽입하기(Responsible youtube Embed) (0) | 2022.12.05 |
재미있게 Flex 공부하기 - Flexbox Froggy 문제풀이 13~24 (0) | 2022.12.02 |
댓글