CSSでの余白付きレスポンシブグリッド
それでは、余白付きのグリッドを作成してみましょう。 以下が完成予想図の例です:
まず、ブロックの親要素にスタイルを設定します:
.parent {
display: flex;
flex-wrap: wrap;
width: 95%;
margin: 50px auto;
}
次に、ブロック自体にスタイルを設定します。 幅はまだ設定せず、パーセントで下マージンを設定します:
.child {
box-sizing: border-box;
height: 100px;
padding: 20px;
margin-bottom: 1.5%;
border: 1px solid green;
}
次に、4つのブロックを横に並べ、適切な余白を設定するコードを書きます:
@media (min-width: 1000px) {
.child {
width: calc(100% / 4 - 1.5% * 3 / 4);
}
.child:not(:nth-child(4n)) {
margin-right: 1.5%;
}
}
次に、3つのブロックを横に並べます:
@media (min-width: 700px) and (max-width: 1000px) {
.child {
width: calc(100% / 3 - 1.5% * 2 / 3);
}
.child:not(:nth-child(3n)) {
margin-right: 1.5%;
}
}
次に、2つのブロックを横に並べます:
@media (min-width: 400px) and (max-width: 700px) {
.child {
width: calc(100% / 2 - 1.5% * 1 / 2);
}
.child:not(:nth-child(2n)) {
margin-right: 1.5%;
}
}
1つのブロックを横に並べます:
@media (max-width: 400px) {
.child {
width: 100%;
}
}
すべてのコードをまとめてみましょう:
.parent {
display: flex;
flex-wrap: wrap;
width: 95%;
margin: 50px auto;
}
.child {
box-sizing: border-box;
height: 100px;
padding: 20px;
margin-bottom: 1.5%;
border: 1px solid green;
}
@media (max-width: 400px) {
.child {
width: 100%;
}
}
@media (min-width: 400px) and (max-width: 700px) {
.child {
width: calc(100% / 2 - 1.5% * 1 / 2);
}
.child:not(:nth-child(2n)) {
margin-right: 1.5%;
}
}
@media (min-width: 700px) and (max-width: 1000px) {
.child {
width: calc(100% / 3 - 1.5% * 2 / 3);
}
.child:not(:nth-child(3n)) {
margin-right: 1.5%;
}
}
@media (min-width: 1000px) {
.child {
width: calc(100% / 4 - 1.5% * 3 / 4);
}
.child:not(:nth-child(4n)) {
margin-right: 1.5%;
}
}
画面サイズが小さくなるにつれて、
最初は1行に8つの要素、
次に1行に4つの要素、
最後に1行に2つの要素を持つグリッドを作成してください。
要素間の余白を0.75%とします。
前のタスクを修正して、要素間の余白を
20pxの固定値にしてください。