Forms
Basic example
A basic example of a simple login form with input fields (email and password), checkbox and submit button.
Checkbox and "forgot password" link are positioned inline by using 2 column grid layout.
Every group of form fields should reside in a form
element. Bootstrap 5 material
design provides no default styling for the form
element, but there are some powerful
browser features that are provided by default.
Login form
Typical login form with additional register buttons.
Register form
Typical register form with additional register buttons.
Contact form
Typical contact form with textarea input as a message field.
Subscription form
A typical subscription form used when subscribing to the newsletter.
Checkout form
IAn example of the extended form with typical checkout inputs.
Login-register
By using pills you can place login and register forms into a single component.
Layout
There are multiple ways to structure forms and provide them the desired layout. Have a look at the examples below to learn more about forms layout.
Utilities
Margin utilities are the easiest way to add some structure to forms. They provide basic grouping of
labels, inputs, optional form text, and form validation messaging. We recommend sticking to
margin-bottom
utilities, and using a single direction throughout the form for consistency.
Feel free to build your forms however you like, with fieldset
s, Div
s, or
nearly any other element.
In the example below, we add .mb-4
class to provide a proper margin between two input
fields.
Form grid
More complex forms can be built using our grid classes. Use these for form layouts that require multiple columns, varied widths, and additional alignment options.
Gutters
By adding gutter modifier classes, you can have input over the gutter width in as well the inline as block direction.
Column sizing
As shown in the previous examples, our grid system allows you to place any number of .cols
within a .row
. They’ll split the available width equally between them. You may also pick a subset of your columns to take up more or less space, while the remaining .cols
equally split the rest, with specific column classes like .col-sm-7
.