Flexbox
Zuletzt aktualisiert
Zuletzt aktualisiert
Flexbox ist eine eindimensionale Layoutmethode zum Anordnen von Elementen in Zeilen oder Spalten. Elemente flexen (dehnen sich aus), um zusätzlichen Raum zu füllen oder ziehen sich zusammen, um in kleinere Räume zu passen.
Zunächst müssen wir auswählen, welche Elemente als flexible Boxen angelegt werden sollen. Dazu setzen wir einen speziellen Wert von display
auf das Elternelement der Elemente, die du beeinflussen möchtest.
Wenn Elemente als Flex-Items angelegt werden, sind sie entlang zwei Achsen angeordnet:
Flexbox bietet eine Eigenschaft namens flex-direction
, die festlegt, in welche Richtung die Hauptachse verläuft. Standardmässig ist dies auf row
gesetzt, was bewirkt, dass sie in einer Zeile angeordnet sind.
Standardmässig versuchen die Flex-Elemente, alle in eine Zeile zu passen. Mit dieser Eigenschaft kannst du das ändern und die Elemente nach Bedarf umbrechen lassen.
justify-content
definiert die Ausrichtung entlang der Hauptachse.
align-items
definiert die Ausrichtung entlang der Querachse.
align-content
richtet die Zeilen eines Flex-Containers aus, wenn in der Querachse zusätzlicher Platz vorhanden ist, ähnlich wie justify-content
einzelne Elemente innerhalb der Hauptachse ausrichtet.
Die Eigenschaft gap
steuert ausdrücklich den Abstand zwischen Flex-Elementen. Dieser Abstand wird nur zwischen den Elementen und nicht an den Aussenkanten angewendet.
Standardmässig werden die Flex-Elemente in der Reihenfolge der Quelle angeordnet. Die Eigenschaft order
steuert jedoch die Reihenfolge, in der sie im Flex-Container erscheinen.
flex-grow
definiert die Fähigkeit eines Flex-Items, bei Bedarf zu wachsen. Er akzeptiert einen einheitenlosen Wert, der als Proportion dient. Er gibt an, wie viel des verfügbaren Platzes innerhalb des Flex-Containers das Element einnehmen soll.
Die flex-shrink
-Eigenschaft legt den Verkleinerungsfaktor eines Flex-Elements fest.
Die flex-basis
-Eigenschaft legt die anfängliche Hauptgrösse eines Flex-Elements fest.
flex
ist die Kurzform für flex-grow
, flex-shrink
und flex-basis
. Der zweite und dritte Parameter (flex-shrink
und flex-basis
) sind optional. Der Standardwert ist 0 1 auto
, aber wenn du einen einzelnen Zahlenwert angibst, z. B. flex: 5;
, ändert sich die flex-basis
auf 0%
, d. h. es ist wie die Einstellung flex-grow: 5; flex-shrink: 1; flex-basis: 0%;
.
flex-grow
flex-shrink