이 레이아웃들은 해당링크동영상을 정리한 것
.parent {
display: grid;
place-items: center;
}
.parent {
display: flex;
flex-wrap: wrap;
justify-content: center; //옵션
}
.box {
flex: 1 1 150px; /* Stretching: */
flex: 0 1 150px; /* No stretching: */
margin: 5px;
}
.parent {
display: grid;
grid-template-columns: minmax(150px, 25%) 1fr;
}
.parent {
display: grid;
grid-template-rows: auto 1fr auto;
}
.parent {
display: grid;
grid-template: auto 1fr auto / auto 1fr auto;
}
header {
padding: 2rem;
grid-column: 1 / 4;
}
.left-side {
grid-column: 1 / 2;
}
main {
grid-column: 2 / 3;
}
.right-side {
grid-column: 3 / 4;
}
footer {
grid-column: 1 / 4;
}
.parent {
display: grid;
grid-template-columns: repeat(12, 1fr);
}
.span-12 {
grid-column: 1 / span 12;
}
.span-6 {
grid-column: 1 / span 6;
}
.span-4 {
grid-column: 4 / span 4;
}
.span-2 {
grid-column: 3 / span 2;
}
/* centering text */
.section {
display: grid;
place-items: center;
text-align: center
}
.parent {
display: grid;
grid-gap: 1rem;
grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
/*grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));*/
}
.card {
display: flex;
flex-direction: column;
padding: 1rem;
justify-content: space-between;
}
여기서 ch
은 character 글자수를 의미함
.card {
width: clamp(23ch, 50%, 46ch);
display: flex;
flex-direction: column;
padding: 1rem;
}
이건 동영상이나 사진 같은 것들의 비율을 정할 때 적합
한데....문제는 아직 모든 브라우저에서 지원하진 않는다.
.visual {
aspect-ratio: 16 / 9;
}
그래서 아직 대신 사용하는것이 padding-top
이다.
.container {
background-color: red;
width: 100%;
padding-top: 100%; /* 1:1 Aspect Ratio */
position: relative; /* If you want text inside of it */
}
/* If you want text inside of the container */
.text {
position: absolute;
top: 0;
left: 0;
bottom: 0;
right: 0;
}
계산방법: calc(세로/가로 * 100%)