연습/CSS
CSS - 반응형 웹 연습
hyeon1016
2024. 9. 4. 00:50
HTML
더보기
<div class="top">내 블로그</div>
<div class="wrap">
<div class="post col-p-3 col-m-4">
<div>
<h2>첫 번째 포스트</h2>
<p>이곳에 포스트 내용을 작성하세요. 반응형 웹 디자인을 배우고 있습니다.</p>
</div>
<div>
<h2>두 번째 포스트</h2>
<p>또 다른 포스트 내용을 작성하세요. 다양한 화면 크기에서 잘 보이도록 합니다.</p>
</div>
</div>
<aside class="sideBar col-p-1 col-m-4">
<h2>사이드 바</h2>
<p>이 곳이 링크 등 추가 가능합니다.</p>
</aside>
</div>
CSS
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
.top {
color: white;
font-size: 3rem;
font-weight: 600;
background-color: black;
text-align: center;
padding: 20px 0px;
}
.wrap {
width: 100%;
height: 300px;
max-width: 100%;
margin: 0 auto;
display: flex;
justify-content: center;
flex-wrap: wrap;
}
@media screen and (min-width : 1024px) {
html {
font-size: 16px;
transition: font-size 0.1s;
}
.col-p-1 {width: 25%;}
.col-p-2 {width: 50%;}
.col-p-3 {width: 70%;}
.col-p-4 {width: 100%;}
}
@media screen and (max-width : 1023px) {
html {
font-size: 12px;
transition: font-size 0.1s;
}
.col-m-1 {width: 25%;}
.col-m-2 {width: 50%;}
.col-m-3 {width: 75%;}
.col-m-4 {width: 100%;}
}
.post div {
height: 100px;
margin: 30px 10px;
padding: 10px;
border-radius: 8px;
box-shadow: 0px 2px 8px #c9c9c9;
}
.post h2 {
margin-bottom: 10px;
font-size: 1.5rem;
/* html 폰트사이즈 기준의 배수 */
}
.post p {
font-size: 1rem;
}
.post div:hover {
background-color: rgb(236, 236, 236);
transition: all 1s;
}
.sideBar {
border-radius: 5px;
background-color: rgb(238, 238, 238);
margin: 30px 10px;
padding: 20px;
}
미디어 쿼리로 화면 너비에 따라 최상위 요소인 html의 글자 크기를 변경하고, 1부터 4까지의 클래스에 각각의 width값을 지정해 둬서 각 요소의 가로 너비를 유동적으로 변경할 수 있게 했다.
문자 크기가 rem단위로 설정된 h2, h3, p는 화면 너비에 따라 유동적으로 문자 크기가 변화 한다.
![]() |