Flex elements nolltillväxt i CSS
Om flex-grow är noll för ett element,
så kommer det elementet inte att delta
i fördelningen av ledigt utrymme.
Som standard är tillväxtfaktorn just
noll, och därför delar element utan angiven
flex-grow inte på det lediga utrymmet
mellan sig.
Låt oss göra en beräkning som exempel.
Antag att vi har tre flex-element,
var och en med en bredd på 100px. Låt det första
elementet inte ha flex-grow (eller så är det
0), det andra elementet har flex-grow,
som är 2, och det tredje - 3.
Antag att förälderns bredd är 500px.
Då blir det lediga utrymmet
200px, och en enhet av flex-grow
kommer att få . Det betyder att bredden
på det första elementet förblir 200px / 5 = 40px100px,
eftersom det inte deltar i fördelningen,
bredden på det andra blir , och bredden på det tredje - 100px + 2 * 40px
= 180px.
100px
+ 3 * 40px = 220px
Praktiska uppgifter
I alla uppgifter nedan kommer du att få se
någon kod med flex-element som har
bredd och flex-grow. Utifrån den presenterade
koden, beräkna vilka dimensioner varje
element kommer att ha. Kör sedan koden
och kontrollera dina beräkningar genom att mäta de faktiska
bredderna på elementen.
<div class="parent">
<div class="child elem1">1</div>
<div class="child elem2">2</div>
<div class="child elem3">3</div>
</div>
.parent {
display: flex;
width: 500px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 200px;
flex-grow: 0;
}
.elem2 {
width: 100px;
flex-grow: 1;
}
.elem3 {
width: 100px;
flex-grow: 1;
}
<div class="parent">
<div class="child elem1">1</div>
<div class="child elem2">2</div>
<div class="child elem3">3</div>
</div>
.parent {
display: flex;
width: 900px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 300px;
flex-grow: 0;
}
.elem2 {
width: 200px;
flex-grow: 3;
}
.elem3 {
width: 100px;
flex-grow: 2;
}
<div class="parent">
<div class="child elem1">1</div>
<div class="child elem2">2</div>
<div class="child elem3">3</div>
<div class="child elem4">4</div>
</div>
.parent {
display: flex;
width: 700px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 200px;
flex-grow: 0;
}
.elem2 {
width: 200px;
flex-grow: 0;
}
.elem3 {
width: 100px;
flex-grow: 1;
}
.elem4 {
width: 100px;
flex-grow: 1;
}