ColumnLayout
Das ColumnLayout organisiert Inhalte in Spalten. Sowohl die Anzahl der Spalten als auch deren Größe lassen sich flexibel für verschiedene Breakpoints definierenGitHubPlayground
Verwende <ColumnLayout />
, um ein ColumnLayout darzustellen.
import ColumnLayout from "@mittwald/flow-react-components/ColumnLayout"; import TextField from "@mittwald/flow-react-components/TextField"; import Label from "@mittwald/flow-react-components/Label"; <ColumnLayout rowGap="s" columnGap="l"> <TextField isRequired> <Label>Vorname</Label> </TextField> <TextField isRequired> <Label>Nachname</Label> </TextField> <TextField isRequired> <Label>Straße</Label> </TextField> <TextField isRequired> <Label>Hausnummer</Label> </TextField> </ColumnLayout>
Das ColumnLayout erzeugt ein flexibles Spalten-Layout, das für die Breakpoints s, m und l individuell angepasst werden kann. Diese Breakpoints beziehen sich nicht auf die Bildschirmgröße, sondern auf die Breite des Containers, in dem das ColumnLayout verwendet wird. Standardmäßig sind die Spalten wie folgt definiert:
- Größe
s
bis 550 Pixel Breite:[1]
- Größe
m
bis 850 Pixel Breite:[1, 1]
- Größe
l
ab 851 Pixel Breite:[1, 1, 1]
In der Definition der Spalten-Breiten werden sowohl die Anzahl der Spalten als auch ihr Größenverhältnis festgelegt. Eine Aufteilung wie [1, 2, 1] erzeugt zum Beispiel drei Spalten, wobei die mittlere Spalte doppelt so breit ist wie die beiden äußeren.
Benutzerdefinierte Werte
Für jeden Breakpoint können eigene Werte für die Spaltenanzahl und deren Größenverhältnis festgelegt werden. Wenn für einen größeren Breakpoint keine eigenen Werte definiert sind, übernimmt er automatisch die Werte des nächstkleineren Breakpoints. Standardwerte werden nur verwendet, wenn bei keinem kleineren Breakpoint benutzerdefinierte Werte angegeben sind. Beispiel:
- Größe
s
bis 550 Pixel Breite:[1]
(Default-Wert) - Größe
m
bis 850 Pixel Breite:[2, 1]
(benutzerdefinierter Wert) - Größe
l
ab 851 Pixel Breite:[2, 1]
(Wert von m geerbt)
In diesem Beispiel wurde für den Breakpoint m
eine benutzerdefinierte
Spaltenaufteilung festgelegt. Der Breakpoint l
übernimmt diese Aufteilung von
m
, anstatt auf den Standardwert von [1, 1, 1]
zurückzufallen. Da für den
Breakpoint s
kein benutzerdefinierter Wert angegeben wurde, bleibt er beim
Standardwert von [1]
.
import ColumnLayout from "@mittwald/flow-react-components/ColumnLayout"; import TextField from "@mittwald/flow-react-components/TextField"; import Label from "@mittwald/flow-react-components/Label"; <ColumnLayout m={[2, 1]}> <TextField isRequired> <Label>Straße</Label> </TextField> <TextField isRequired> <Label>Hausnummer</Label> </TextField> </ColumnLayout>
Abstände
Die Abstände des ColumnLayout können in drei Stufen angepasst werden:
- s = 8px
- m = 16px
- l = 24px
Die property rowGap
steuert die Abstände zwischen den Zeilen (oben und unten),
columnGap
die Abstände zwischen den Spalten (rechts und links) und gap
setzt
alle Abstände gleichzeitig (oben, unten, rechts und links).
import ColumnLayout from "@mittwald/flow-react-components/ColumnLayout"; import TextField from "@mittwald/flow-react-components/TextField"; import Label from "@mittwald/flow-react-components/Label"; <ColumnLayout m={[1, 1]} rowGap="s" columnGap="l"> <TextField isRequired> <Label>Vorname</Label> </TextField> <TextField isRequired> <Label>Nachname</Label> </TextField> <ColumnLayout s={[2, 1]} columnGap="m"> <TextField isRequired> <Label>Straße</Label> </TextField> <TextField isRequired> <Label>Hausnummer</Label> </TextField> </ColumnLayout> <TextField isRequired> <Label>Ort</Label> </TextField> </ColumnLayout>
Grundlagen
Best practices
- Zu viele Spalten können den Content überladen und unübersichtlich machen. In der Regel reichen maximal 4 Spalten aus.
- Integriere bei Bedarf mehrere ColumnLayouts ineinander, um Inhalte optisch zu gruppieren.
- Wähle die Spaltenbreiten bewusst: Einheitliche Breiten schaffen ein harmonisches Layout, während unterschiedliche Breiten den Fokus des Users auf breitere Inhalte lenken.
- Verwende das ColumnLayout in Kombination mit der Section, um einfach übersichtliche Layouts zu erstellen.
Verwendung
Verwende ein ColumnLayout, um ...
- das Layout eines Dashboards festzulegen.
- Formularfeldern eine klare Struktur zu geben.
- Inhalte auf unterschiedlichen Geräten übersichtlich darzustellen.
Verhalten
Responsive layout
Das ColumnLayout folgt folgenden Breakpoints:
- Größe
s
bis 550 Pixel Breite:[1]
- Größe
m
bis 850 Pixel Breite:[1, 1]
- Größe
l
ab 851 Pixel Breite:[1, 1, 1]
Beachte, dass die Breakpoints sich nicht auf die Bildschirmgröße des Endgeräts beziehen. Sie beziehen sich auf die Breite des Containers, in dem das ColumnLayout verwendet wird. Für jeden Breakpoint kann sowohl die Anzahl der Spalten als auch deren Größenverteilung individuell festgelegt werden (siehe Overview). So bricht das Layout automatisch um, wenn es eine bestimmte Breite unterschreitet.