SimpleGrid
Responsive grid in which each item takes equal amount of space
Source
Docs
Package
Usage
SimpleGrid is a responsive grid system with equal-width columns.
It uses CSS grid layout. If you need to set different widths for columns, use
Grid component instead.
1
2
3
4
5
spacing and verticalSpacing props
spacing prop is used both for horizontal and vertical spacing if verticalSpacing is not set:
Responsive props
cols, spacing and verticalSpacing props support object notation for responsive values,
it works the same way as style props: the object may have base, xs,
sm, md, lg and xl key, and values from those keys will be applied according to current
viewport width.
In the following example, cols={{ base: 1, sm: 2, lg: 5 }} means:
- 1 column if viewport width is less than
smbreakpoint - 2 columns if viewport width is between
smandlgbreakpoints - 5 columns if viewport width is greater than
lgbreakpoint
Same logic applies to spacing and verticalSpacing props.
1
2
3
4
5
Container queries
To use container queries
instead of media queries, set type="container". With container queries, grid columns and spacing
will be adjusted based on the container width, not the viewport width.
Note that, when using container queries, cols, spacing and verticalSpacing props cannot
reference theme.breakpoints values in keys. It is required to use exact px or em values.
To see how the grid changes, resize the root element of the demo with the resize handle located at the bottom right corner of the demo:
Browser support
SimpleGrid uses CSS Grid Layout, it is supported in all modern browsers.
If you need to support older browsers, use Grid (flexbox based) component instead.
When type="container" is set, SimpleGrid uses container queries.
Since February 2023, container queries are supported in all modern browsers. If you need to support older browsers,
do not use container queries option.