⊗mkSpFxSFC 96 of 128 menu

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; }
Español
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
Usamos cookies para el funcionamiento del sitio, análisis y personalización. El procesamiento de datos se realiza de acuerdo con la Política de privacidad.
aceptar todas configurar rechazar