Нулева алчност на флекс елементите во CSS
Ако flex-grow е еднаков на нула за некој
елемент, тогаш тој елемент нема да учествува
во распределбата на слободниот простор.
Според стандардните поставки, алчноста има
нулта вредност и затоа елементите без зададена
flex-grow вредност не го делат слободниот простор
помеѓу себе.
Ајде да направиме некоја пресметка за пример.
Да претпоставиме дека имаме три флекс-елементи,
секој со ширина од 100px. Нека првиот
елемент нема зададено flex-grow (или вредноста
е 0), вториот елемент има flex-grow
вредност 2, а третиот - 3.
Нека ширината на родителот е 500px.
Тогаш слободниот простор ќе биде
200px, а на една единица flex-grow
ќе и припадне . Ќе испадне дека ширината
на првиот елемент ќе остане 200px / 5 = 40px100px,
бидејќи не учествува во распределбата,
ширината на вториот ќе биде , а ширината на третиот - 100px + 2 * 40px
= 180px.
100px
+ 3 * 40px = 220px
Практични задачи
Во сите задачи подолу ќе ви биде претставен
некој код со флекс-елементи кои имаат
ширина и flex-grow вредност. Според претставениот
код, пресметајте какви димензии ќе има
секој од елементите. Потоа стартувајте го кодот
и проверете ги вашите пресметки, со мерење на реалните
ширини на елементите.
<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;
}