title: Columns
storybookPath: page-layout-columns--default
isExperimentalPackage: false
Use the columns primitive to layout content in configurable columns.
Each child represents a single column. By default that column will span 1
fraction of the total number of children.
<Columns>
<Placeholder />
<Placeholder />
<Placeholder />
</Columns>
Examples
Gap
The spacing between children can be adjusted using the gap
prop.
<Columns gap="large">
<Placeholder />
<Placeholder />
<Placeholder />
</Columns>
Vertical alignment
Columns can be aligned vertically using the alignY
prop.
<Stack gap="medium" dividers>
<Columns gap="small" alignY="top">
<Placeholder />
<Placeholder label="top (default)" height={64} />
<Placeholder />
</Columns>
<Columns gap="small" alignY="center">
<Placeholder />
<Placeholder label="center" height={64} />
<Placeholder />
</Columns>
<Columns gap="small" alignY="bottom">
<Placeholder />
<Placeholder label="bottom" height={64} />
<Placeholder />
</Columns>
<Columns gap="small" alignY="stretch">
<Placeholder />
<Placeholder label="stretch" height={64} />
<Placeholder />
</Columns>
</Stack>
Collapsing across breakpoints
Columns can be collapsed into a single vertical stack responsively using the
collapseBelow
prop.
<Columns gap="large" collapseBelow="desktop">
<Placeholder />
<Placeholder />
<Placeholder />
</Columns>
Template
If you need more control over how your columns are distributed, you can use the
template
prop. template
receives an array of numbers that represent the
relative width of each column.
<Columns gap="small" template={[1, 3, 1]} collapseBelow="tablet">
<Box border="field" padding="small">
<Text>nav</Text>
</Box>
<Box border="field" padding="small">
<Text>main</Text>
</Box>
<Box border="field" padding="small">
<Text>aside</Text>
</Box>
</Columns>
Props
Box
props are also included as Column
props and are not
listed here (excluding display
, alignItems
, gap
, flexDirection
,
justifyContent
and flexWrap
).
Extra props are passed into the underlying Box
component.