Grid
Grid acts as a generic container, wrapping around the elements to be arranged.
Introduction
The Grid component, based on a 12-column grid layout, creates visual consistency between layouts while allowing flexibility across a wide variety of designs.
Basics
<span class="token keyword">import</span> Grid <span class="token keyword">from</span> <span class="token string">'@mui/joy/Grid'</span><span class="token punctuation">;</span>
Column widths are integer values between 1 and 12. They apply at any breakpoint and indicate how many columns are occupied by the component.
By default, the value given to a breakpoint is applied to all the other wider breakpoints.
For example, xs={12}
sizes a component to occupy the whole viewport width regardless of its size, even if you do not pass any value for wider breakpoints like sm
or md
.
Customization
Grid with multiple breakpoints
Components may have multiple widths defined, causing the layout to change at the defined breakpoint. Width values given to larger breakpoints override those given to smaller breakpoints.
For example, xs={12} sm={6}
sizes a component to occupy half of the viewport width (6 columns) when viewport width is 600 or more pixels. For smaller viewports, the component fills all 12 available columns.
Spacing
To control space between children, use the spacing
prop.
The spacing value can be any positive number, including decimals and any string.
The prop is converted into a CSS property using the theme.spacing()
helper.
<Grid container spacing={2}>
Row & column spacing
The rowSpacing
and columnSpacing
props allow for specifying the row and column gaps independently.
It's similar to the row-gap
and column-gap
properties of CSS Grid.
Responsive values is supported by:
columns
columnSpacing
direction
rowSpacing
spacing
- all the other props of the system
Auto-layout
The Auto-layout makes the grid items equitably share the available space. This also means that you can set the width of one grid item, and the others will automatically resize around it.
Variable width content
Set one of the size breakpoint props to "auto"
instead of true
or a number
to render a column based on the natural width of its content.
System props
As a CSS utility component, Grid supports all MUI System properties. You can use them as props directly on the component. For instance, a margin-top:
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span><span class="token class-name">Grid</span></span> <span class="token attr-name">mt</span><span class="token script language-javascript"><span class="token script-punctuation punctuation">=</span><span class="token punctuation">{</span><span class="token number">2</span><span class="token punctuation">}</span></span><span class="token punctuation">></span></span>
Interactive demo
Below is an interactive demo that lets you explore the visual results of the different settings:
<Grid
container
direction="row"
justifyContent="center"
alignItems="center"
>
Limitations
Negative margin
The spacing between items is implemented with a negative margin. This might lead to unexpected behaviors. For instance, to apply a background color, you need to apply display: flex;
to the parent.
direction: column | column-reverse
The xs
, sm
, md
, lg
, and xl
props are not supported within direction="column"
and direction="column-reverse"
containers.
They define the number of grids the component will use for a given breakpoint. They are intended to control width using flex-basis
in row
containers but they will impact height in column
containers.
If used, these props may have undesirable effects on the height of the Grid
item elements.
CSS Grid Layout
The Grid
component is using CSS flexbox internally.
But as seen below, you can easily use the system and CSS Grid to layout your pages.
Common examples
Centering children
To center a grid item's content, specify display="flex"
directly on the item.
Then use justifyContent
and/or alignItems
to adjust the position of the content, as shown below:
Jimmy
Michal
Jun
Marija
Anatomy
The Grid component is composed of a single root <div>
element:
<span class="token tag"><span class="token tag"><span class="token punctuation"><</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>MuiGrid-root<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
<span class="token comment"><!-- Grid contents --></span>
<span class="token tag"><span class="token tag"><span class="token punctuation"></</span>div</span><span class="token punctuation">></span></span>