flex-shrink
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2015.
Die flex-shrink
CSS-Eigenschaft legt den Verkleinerungsfaktor eines Flex-Elements fest. Wenn die Größe aller Flex-Elemente größer als der Flex-Container ist, können die Flex-Elemente verkleinert werden, um entsprechend ihrem flex-shrink
-Wert zu passen. Der negative freie Raum jeder Flexzeile wird zwischen den Flex-Elementen der Zeile verteilt, die einen flex-shrink
-Wert größer als 0
haben.
Hinweis:
Es wird empfohlen, die flex
Kurznotation anstelle separater Deklarationen von flex-shrink
, flex-grow
und flex-basis
zu verwenden. Wir haben sie hier getrennt, da dieses Dokument eine der Komponenten der flex
-Kurznotation behandelt: die flex-shrink
-Eigenschaft.
Probieren Sie es aus
flex-shrink: 0;
flex-shrink: 1;
flex-shrink: 2;
<section class="default-example" id="default-example">
<div class="transition-all" id="example-element">I shrink</div>
<div>Item Two</div>
<div>Item Three</div>
</section>
.default-example {
border: 1px solid #c5c5c5;
width: auto;
max-height: 300px;
display: flex;
}
.default-example > div {
background-color: rgba(0, 0, 255, 0.2);
border: 3px solid blue;
margin: 10px;
flex-grow: 1;
flex-shrink: 1;
flex-basis: 300px;
}
Syntax
/* <number> values */
flex-shrink: 2;
flex-shrink: 0.6;
/* Global values */
flex-shrink: inherit;
flex-shrink: initial;
flex-shrink: revert;
flex-shrink: revert-layer;
flex-shrink: unset;
Beschreibung
Die flex-shrink
-Eigenschaft spezifiziert den Verkleinerungsfaktor, der bestimmt, wie stark das Flex-Element im Vergleich zu den restlichen Flex-Elementen im Flex-Container schrumpfen wird, wenn negativer freier Raum verteilt wird.
Diese Eigenschaft behandelt Situationen, in denen der Browser die flex-basis-Werte der Flex-Elemente berechnet und feststellt, dass sie zu groß sind, um in den Flex-Container zu passen. Solange flex-shrink
einen positiven Wert hat, werden die Elemente geschrumpft, damit sie nicht den Container überfluten.
Die flex-grow
-Eigenschaft behandelt die Verteilung des verfügbaren positiven freien Raums proportional zum Wachstumsfaktor jedes Elements, wobei der Wert der flex-grow
-Eigenschaft die einzige Überlegung darstellt. Die flex-shrink
-Eigenschaft verwaltet das Entfernen von negativem freien Raum, um die Boxen in ihren Container passen zu lassen, ohne dass sie überfluten. Das Entfernen von Raum ist etwas komplizierter als das Hinzufügen von Raum. Der Verkleinerungsfaktor wird mit der Basisgröße des Flex-Elements multipliziert; dies verteilt negativen Raum proportional dazu, wie stark das Element schrumpfen kann. Dies verhindert, dass kleinere Elemente auf 0px
schrumpfen, bevor ein größerer Gegenstand merklich reduziert wird.
Im Allgemeinen wird flex-shrink
zusammen mit den Eigenschaften flex-grow
und flex-basis
verwendet. Innerhalb der flex
-Kurznotation ist der Verkleinerungsfaktor immer die zweite <number>
. Wenn die Kurznotation nur einen numerischen Wert enthält, wird angenommen, dass dieser Wert der flex-grow
-Wert ist.
Werte
Formale Definition
Anfangswert | 1 |
---|---|
Anwendbar auf | flexible Elemente einschließlich In-Flow-Pseudo-Elemente |
Vererbt | Nein |
Berechneter Wert | wie angegeben |
Animationstyp | Nummer |
Formale Syntax
flex-shrink =
<number [0,∞]>
Beispiele
Verkleinerungsfaktor von Flex-Elementen festlegen
Dieses Beispiel zeigt, wie negativer freier Raum basierend auf dem Verkleinerungsfaktor des Elements verteilt wird. Es umfasst fünf Flex-Elemente mit einem flex-shrink
-Wert größer als 0, die eine kombinierte Breite haben, die größer ist als die Breite ihres übergeordneten Flex-Containers.
HTML
<div id="content">
<div class="box" style="background-color:red;">A</div>
<div class="box" style="background-color:lightblue;">B</div>
<div class="box" style="background-color:yellow;">C</div>
<div class="box4" style="background-color:lightsalmon;">D</div>
<div class="box5" style="background-color:lightgreen;">E</div>
</div>
CSS
Wir geben jedem Flex-Element eine width
von 200px
. Da die Eigenschaft flex-basis
standardmäßig auf auto
steht, beträgt die flex-basis jedes Elements 200px
. Dies gibt den Flex-Elementen eine Gesamtbreite von 1000px
, doppelt so groß wie der Container. Wir setzen alle Flex-Elemente so, dass sie verkleinert werden können, mit flex-shrink
-Werten größer als 0
. Die letzten beiden Elemente haben höhere flex-shrink
-Werte festgelegt, sodass sie stärker schrumpfen.
#content {
display: flex;
width: 500px;
}
#content div {
width: 200px;
}
.box {
flex-shrink: 1;
}
.box4 {
flex-shrink: 1.5;
}
.box5 {
flex-shrink: 2;
}
Ergebnis
Die Flex-Elemente überlaufen ihren Container nicht, da sie schrumpfen können: die 500px
negativer freier Raum wird unter den fünf Elementen basierend auf ihren flex-shrink
-Werten verteilt. Die ersten drei Elemente haben flex-shrink: 1
gesetzt. D hat flex-shrink: 1.5
und E hat flex-shrink: 2
gesetzt. Die endgültige Breite von D und E ist geringer als die der anderen, wobei E kleiner als D ist.
Spezifikationen
Specification |
---|
CSS Flexible Box Layout Module Level 1 # flex-shrink-property |