Regulación de la compresión de bloques flex en CSS
Por defecto, a todos los elementos se les recortan
trozos proporcionales al ancho del elemento.
Sin embargo, es posible hacer que a algunos
elementos se les recorten trozos más grandes o más
pequeños. Para ello existe una propiedad especial
flex-shrink.
Esta propiedad representa un peso determinado
por el cual se multiplicará el ancho del elemento
al calcular el trozo a recortar según la
fórmula ya mencionada anteriormente. Por ejemplo, si
el ancho del elemento es 200px, y su
flex-shrink es 3, entonces el ancho
ponderado (es decir, multiplicado por el peso)
del elemento será:
200px * 3 = 600px
La fórmula teniendo en cuenta flex-shrink
tendrá la siguiente forma: espacio negativo libre
* (ancho ponderado del elemento / suma de todos
los anchos ponderados de los elementos).
Veamos un ejemplo. Supongamos que tenemos
4 elementos. Sea el ancho del primer
elemento 400px, y su flex-shrink
es 2, el ancho del resto de los elementos
- 200px, y su flex-shrink es
1. Sea el ancho del padre 900px.
El ancho total de los elementos es:
400px + 3 * 200px = 1000px
El espacio libre negativo será:
1000px - 900px = 100px
El ancho ponderado total de los elementos es:
400px * 2 + 200px * 1 + 200px * 1 + 200px * 1 = 1400px
El ancho ponderado del primer elemento es:
400px * 2 = 800px
Al primer elemento se le recortará el siguiente trozo:
100px * (800px / 1400px) = 100px * 0.57 = 57.14px
El ancho del elemento será:
400px - 57.14px = 342.86px ~ 343px
El ancho ponderado de cada uno de los demás elementos es:
200px * 1 = 200px
A cada elemento se le recortará el siguiente trozo:
100px * (200px / 1400px) = 100px * 0.142 = 14.2px
El ancho del elemento será:
200px - 14.2px = 185.8px ~ 186px
Implemente los bloques descritos y compruebe mediante medición que el ancho de los elementos será efectivamente igual al que hemos calculado.
Calcule el ancho de los bloques y luego compruebe los cálculos mediante medición:
<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: 200px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 100px;
flex-shrink: 2;
}
.elem2 {
width: 100px;
flex-shrink: 1;
}
.elem3 {
width: 100px;
flex-shrink: 1;
}
Calcule el ancho de los bloques y luego compruebe los cálculos mediante medición:
<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: 200px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 100px;
flex-shrink: 3;
}
.elem2 {
width: 100px;
flex-shrink: 2;
}
.elem3 {
width: 100px;
flex-shrink: 1;
}
Calcule el ancho de los bloques y luego compruebe los cálculos mediante medición:
<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: 500px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 300px;
flex-shrink: 3;
}
.elem2 {
width: 200px;
flex-shrink: 2;
}
.elem3 {
width: 200px;
flex-shrink: 1;
}
.elem4 {
width: 200px;
flex-shrink: 1;
}