Grid system uses a series of containers, rows, and columns to layout and align content. It’s built with flexbox and is fully responsive. Below is an example and an in-depth look at how the grid comes together. New to or unfamiliar with flexbox? Read this CSS Tricks flexbox guide for background, terminology, guidelines, and code snippets.
This example creates three equal-width columns on small, medium, large, and extra large devices using our predefined grid classes. Those columns are centered in the page with the parent .container
.
Breaking it down, here’s how it works:
.container
for a responsive pixel width or .container-fluid
for width: 100%
across all viewport and device sizes.padding
(called a gutter) for controlling the space between them. This padding
is then counteracted on the rows with negative margins. This way, all the content in your columns is visually aligned down the left side.width
will automatically layout as equal width columns. For example, four instances of .col-sm
will each automatically be 25% wide from the small breakpoint and up. See the auto-layout columns section for more examples..col-4
.width
s are set in percentages, so they’re always fluid and sized relative to their parent element.padding
to create the gutters between individual columns, however, you can remove the margin
from rows and padding
from columns with .no-gutters
on the .row
..col-sm-4
applies to small, medium, large, and extra large devices, but not the first xs
breakpoint)..col-4
)See how aspects of the grid system work across multiple devices:
XS <550px |
S ≥769px |
M ≥992px |
L ≥1280px |
XL ≥1440px |
XXL ≥1680px |
|
---|---|---|---|---|---|---|
Max container width | None (auto) | 90% | 90% | 90% | 1250px | 1650px |
Class prefix | .col- |
.col-sm- |
.col-md- |
.col-lg- |
.col-xl- |
.col-xl- |
# of columns | 12 | |||||
Gutter width | 30px (15px on each side of a column) | |||||
Nestable | Yes | |||||
Column ordering | Yes |
<div class="container">
<div class="row">
<div class="col-sm"> One of three columns </div>
<div class="col-sm"> One of three columns </div>
<div class="col-sm"> One of three columns </div>
</div>
</div>
<div class="container">
<div class="row">
<div class="col-sm-8"> col-sm-8 </div>
<div class="col-sm-4"> col-sm-4 </div>
</div>
</div>