Responsiv CSS-rutnät med marginaler
Låt oss nu skapa ett rutnät med marginaler. Här är ett exempel på vad vi borde få:
Låt oss börja med att skapa stilar för förälderelementet till blocken:
.parent {
display: flex;
flex-wrap: wrap;
width: 95%;
margin: 50px auto;
}
Nu sätter vi stilar för själva blocken, utan att sätta bredd för dem, men med en bottenmarginal i procent:
.child {
box-sizing: border-box;
height: 100px;
padding: 20px;
margin-bottom: 1.5%;
border: 1px solid green;
}
Nu skriver vi kod som placerar fyra block på rad, med motsvarande marginaler:
@media (min-width: 1000px) {
.child {
width: calc(100% / 4 - 1.5% * 3 / 4);
}
.child:not(:nth-child(4n)) {
margin-right: 1.5%;
}
}
Och nu placerar vi tre block på rad:
@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%;
}
}
Och nu placerar vi två block på rad:
@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%;
}
}
Ett block på rad:
@media (max-width: 400px) {
.child {
width: 100%;
}
}
Låt oss samla all kod tillsammans:
.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%;
}
}
Skapa ett rutnät som när skärmen minskar
först har åtta element på rad,
sedan fyra element på rad, sedan två element
på rad. Låt avståndet mellan elementen vara
0.75%.
Modifiera den föregående uppgiften så att
avståndet mellan elementen är ett fast
värde på 20px.