A wide range of shorthand responsive margin, padding, and gap utility classes.
Assign responsive-friendly margin or padding values to an element or a subset of its sides with shorthand
classes. Includes support for individual properties, all properties, and vertical and horizontal properties.
Classes are built from a default Sass map ranging from .25rem to 3rem.
Spacing utilities that apply to all breakpoints, from xs to xxl, have no breakpoint abbreviation in them.
This is because those classes are applied from min-width: 0 and up, and thus are not bound by a media query.
The remaining breakpoints, however, do include a breakpoint abbreviation.
The classes are named using the format {property}{sides}-{size} for xs and
{property}{sides}-{breakpoint}-{size} for sm, md, lg, xl, and xxl.
Where property is one of:
m - for classes that set marginp - for classes that set paddingWhere sides is one of:
t - for classes that set margin-top or padding-topb - for classes that set margin-bottom or padding-bottoms - (start) for classes that set margin-left or padding-left in LTR, margin-right or padding-right in RTLe - (end) for classes that set margin-right or padding-right in LTR, margin-left or padding-left in RTLx - for classes that set both *-left and *-righty - for classes that set both *-top and *-bottommargin or padding on all 4 sides of the elementWhere size is one of:
0 - for classes that eliminate the margin or padding by setting it to 01 - (by default) for classes that set the margin or padding to $spacer * .252 - (by default) for classes that set the margin or padding to $spacer * .53 - (by default) for classes that set the margin or padding to $spacer4 - (by default) for classes that set the margin or padding to $spacer * 1.55 - (by default) for classes that set the margin or padding to $spacer * 3auto - for classes that set the margin to auto(You can add more sizes by adding entries to the $spacers Sass map variable.)
Here are some representative examples of these classes:
.mt-0 {
margin-top: 0 !important;
}
.ms-1 {
margin-left: ($spacer * .25) !important;
}
.px-2 {
padding-left: ($spacer * .5) !important;
padding-right: ($spacer * .5) !important;
}
.p-3 {
padding: $spacer !important;
}
Material Style includes an .mx-auto class for horizontally centering fixed-width block level content—that is,
content that has display: block and a width set—by setting the horizontal margins to auto.
<div class="mx-auto p-2 text-bg-success" style="width: 200px;">
Centered element
</div>In CSS, margin properties can utilize negative values (padding cannot). These negative margins are
disabled by default, but can be enabled in Sass by setting $enable-negative-margins: true.
The syntax is nearly the same as the default, positive margin utilities, but with the addition of n
before the requested size. Here’s an example class that’s the opposite of .mt-1:
.mt-n1 {
margin-top: -0.25rem !important;
}
When using display: grid or display: flex, you can make use of gap utilities on the parent element.
This can save on having to add margin utilities to individual children of a grid or flex container.
Gap utilities are responsive by default, and are generated via our utilities API, based on the $spacers
Sass map.
<div class="d-flex flex-wrap gap-3">
<div class="p-2 col-5 text-bg-success">Flex item 1</div>
<div class="p-2 col-5 text-bg-success">Flex item 2</div>
<div class="p-2 col-5 text-bg-success">Flex item 3</div>
<div class="p-2 col-5 text-bg-success">Flex item 4</div>
</div>Support includes responsive options for all of Bootstrap’s grid breakpoints, as well as six sizes from the
$spacers map (0–5). There is no .gap-auto utility class as it’s effectively the same as .gap-0.
row-gaprow-gap sets the vertical space between children items in the specified container.
<div class="d-flex flex-wrap row-gap-3">
<div class="p-2 col-6 text-bg-success">Flex item 1</div>
<div class="p-2 col-6 text-bg-success">Flex item 2</div>
<div class="p-2 col-6 text-bg-success">Flex item 3</div>
<div class="p-2 col-6 text-bg-success">Flex item 4</div>
</div>column-gapcolumn-gap sets the horizontal space between children items in the specified container.
<div class="d-flex flex-wrap column-gap-3">
<div class="p-2 col-5 text-bg-success">Flex item 1</div>
<div class="p-2 col-5 text-bg-success">Flex item 2</div>
<div class="p-2 col-5 text-bg-success">Flex item 3</div>
<div class="p-2 col-5 text-bg-success">Flex item 4</div>
</div>