Korrekt marginaljusterad CSS-kakel
Låt oss skapa en kakel med marginaler som verkligen fungerar utan problem. Låt oss säga att vi initialt har en sådan kakel utan marginaler:
<div class="parent">
<div class="child">1</div>
<div class="child">2</div>
<div class="child">3</div>
<div class="child">4</div>
<div class="child">5</div>
<div class="child">6</div>
<div class="child">7</div>
<div class="child">8</div>
<div class="child">9</div>
</div>
.parent {
display: flex;
flex-wrap: wrap;
width: 300px;
border: 1px solid red;
}
.child {
box-sizing: border-box;
width: 100px;
height: 100px;
border: 1px solid green;
}
:
Låt oss skapa horisontella marginaler mellan
elementen med margin.
För att göra detta, sätt
margin-right till 10px för alla barnelement,
och nollställ denna margin för vart tredje barnelement.
Använd pseudoklassen nth-child för detta,
och ställ in parametern så att du får
var tredje element.
Låt oss också öka bredden på föräldern till 320px
för att ge plats för marginalerna, och se
vad vi får:
<div class="parent">
<div class="child">1</div>
<div class="child">2</div>
<div class="child">3</div>
<div class="child">4</div>
<div class="child">5</div>
<div class="child">6</div>
<div class="child">7</div>
<div class="child">8</div>
<div class="child">9</div>
</div>
.parent {
display: flex;
flex-wrap: wrap;
width: 320px;
border: 1px solid red;
}
.child {
box-sizing: border-box;
width: 100px;
height: 100px;
margin-right: 10px;
border: 1px solid green;
}
.child:nth-child(3n) {
margin-right: 0;
}
:
Så, allt fungerar. Låt oss ta bort det sista elementet, så att den sista raden har färre element och se till att vi inte får problem med den sista raden:
<div class="parent">
<div class="child">1</div>
<div class="child">2</div>
<div class="child">3</div>
<div class="child">4</div>
<div class="child">5</div>
<div class="child">6</div>
<div class="child">7</div>
<div class="child">8</div>
</div>
.parent {
display: flex;
flex-wrap: wrap;
width: 320px;
border: 1px solid red;
}
.child {
box-sizing: border-box;
width: 100px;
height: 100px;
margin-right: 10px;
border: 1px solid green;
}
.child:nth-child(3n) {
margin-right: 0;
}
:
Skapa en kakel med två element per rad med
ett avstånd mellan elementen på 20px.