Flexbox
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.
.container {
display: flex;
}Das Flex-Modell
Wenn Elemente als Flex-Items angelegt werden, sind sie entlang zwei Achsen angeordnet:
Spalten oder Zeilen
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.
.container {
display: flex;
flex-direction: row | column | row-reverse | column-reverse;
}Umbrüche
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.
.container {
display: flex;
flex-wrap: nowrap | wrap | wrap-reverse;
}Horizontale und Vertikale Ausrichtung
justify-content definiert die Ausrichtung entlang der Hauptachse.
.container {
display: flex;
justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly;
}align-items definiert die Ausrichtung entlang der Querachse.
.container {
display: flex;
align-items: stretch | flex-start | flex-end | center | baseline;
}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.
.container {
align-content: flex-start | flex-end | center | space-between | space-around | space-evenly | stretch;
}Abstände
Die Eigenschaft gap steuert ausdrücklich den Abstand zwischen Flex-Elementen. Dieser Abstand wird nur zwischen den Elementen und nicht an den Aussenkanten angewendet.
.container {
display: flex;
...
gap: 1rem;
gap: 1rem 2rem;
row-gap: 1rem;
column-gap: 2rem;
}Flex-Items anordnen
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.
.item {
order: 5;
}Flexible Grössenanpassung
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.
.item {
flex-grow: 2;
}flex-growDie flex-shrink-Eigenschaft legt den Verkleinerungsfaktor eines Flex-Elements fest.
.item {
flex-shrink: 2;
}flex-shrinkDie flex-basis-Eigenschaft legt die anfängliche Hauptgrösse eines Flex-Elements fest.
.item {
flex-basis: 20%;
}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%;.
.item {
flex: 2;
}Last updated