Form group
Wrapping controls in .form-group gives them a margin at the bottom.
<div class="form-group"> <label>Label</label> <input type="text" class="form-control"> </div>
Inline
Make elements appear inline by giving the form or maste div a class of form-inline.
<div class="form-inline"> <label class="mr-2" for="formControlInline1">Name:</label> <input type="text" class="form-control mr-2" value="Dwight Schrute" id="formControlInline1"> <div class="form-select mr-2"> <select class="form-control"> <option>Beets</option> <option>Bears</option> <option>Battlestar Galactica</option> </select> </div> <div class="form-checkbox mr-2"> <input type="checkbox" id="checkboxInline1" class="form-control-checkbox"> <label for="checkboxInline1" class="form-label-checkbox">I agree</label> </div> <button class="btn btn-primary">Save</button> </div>
Input
Inputs are column-styled (label over input) as default but can be row-styled (label to the left of input) using the .row and .col-* classes. Note that the .col-form-label class must be used on the label to align it vertically.
When using the sizing classes in the inputs, the corresponding sizing class has to be assigned o the label (.col-form-label-sm / -lg).
<div class="form-group"> <label for="input1">Label</label> <input type="text" class="form-control" id="input1" value="Input"> </div> <div class="form-group"> <input type="text" class="form-control" id="input1" value="Disabled input" disabled> </div> <div class="form-group row"> <label for="input2" class="col-2 col-form-label-sm">Label</label> <div class="col-10"> <input type="text" class="form-control form-control-sm" id="input2" value="Input"> </div> </div> <div class="form-group row"> <label for="input2" class="col-2 col-form-label">Label</label> <div class="col-10"> <input type="text" class="form-control" id="input2" value="Input"> </div> </div> <div class="form-group mb-0 row"> <label for="input2" class="col-2 col-form-label-lg">Label</label> <div class="col-10"> <input type="text" class="form-control form-control-lg" id="input2" value="Input"> </div> </div>
Sizing
<input type="text" class="form-control form-control-sm" id="input1" value="Small input"> <input type="text" class="form-control" id="input1" value="Default input"> <input type="text" class="form-control form-control-lg" id="input1" value="Large input">
Textarea
<label for="textarea">Label</label> <textarea class="form-control" id="textarea" placeholder="This is a textarea..."></textarea>
Checkbox and radio
<div class="form-group"> <div class="form-checkbox"> <input type="checkbox" id="checkboxExample1" class="form-control-checkbox" checked> <label for="checkboxExample1" class="form-label-checkbox">Default checkbox</label> </div> <div class="form-checkbox"> <input type="checkbox" id="checkboxExample2" class="form-control-checkbox" disabled> <label for="checkboxExample2" class="form-label-checkbox">Disabled checkbox</label> </div> </div> <div class="form-group mb-0"> <div class="form-radio"> <input type="radio" name="radioExample" id="radioExample1" class="form-control-radio" checked> <label for="radioExample1" class="form-label-radio">Default radio 1</label> </div> <div class="form-radio"> <input type="radio" name="radioExample" id="radioExample2" class="form-control-radio"> <label for="radioExample2" class="form-label-radio">Default radio 2</label> </div> <div class="form-radio"> <input type="radio" name="radioExample" id="radioExample2" class="form-control-radio" disabled> <label for="radioExample2" class="form-label-radio">Disabled radio</label> </div> </div>
Checkbox and radio inline
<div class="form-group"> <div class="form-checkbox form-control-inline"> <input type="checkbox" id="checkboxInlineExample1" class="form-control-checkbox" checked> <label for="checkboxInlineExample1" class="form-label-checkbox">Default checkbox</label> </div> <div class="form-checkbox form-control-inline"> <input type="checkbox" id="checkboxInlineExample2" class="form-control-checkbox" disabled> <label for="checkboxInlineExample2" class="form-label-checkbox">Disabled checkbox</label> </div> </div> <div class="form-group"> <div class="form-radio form-control-inline"> <input type="radio" name="radioInlineExample" id="radioInlineExample1" class="form-control-radio" checked> <label for="radioInlineExample1" class="form-label-radio">Deafult radio</label> </div> <div class="form-radio form-control-inline"> <input type="radio" name="radioInlineExample" id="radioInlineExample2" class="form-control-radio"> <label for="radioInlineExample2" class="form-label-radio">Default radio</label> </div> <div class="form-radio form-control-inline"> <input type="radio" name="radioInlineExample" id="radioInlineExample3" class="form-control-radio" disabled> <label for="radioInlineExample3" class="form-label-radio">Disabled radio</label> </div> </div>
Switches
<div class="form-switch"> <input type="checkbox" id="switchExample1" class="form-control-switch"> <label for="switchExample1" class="form-label-switch">Default switch</label> </div> <div class="form-switch"> <input type="checkbox" id="switchExample2" class="form-control-switch" disabled> <label for="switchExample2" class="form-label-switch">Disabled switch</label> </div>
Select
<div class="form-group"> <label>Label</label> <div class="form-select"> <select class="form-control form-control-sm"> <option>Small select</option> <option>Option</option> </select> </div> </div> <div class="form-group"> <div class="form-select"> <select class="form-control"> <option>Default select</option> <option>Option</option> </select> </div> </div> <div class="form-group"> <div class="form-select"> <select class="form-control form-control-lg"> <option>Large select</option> <option>Option</option> </select> </div> </div> <div class="form-group"> <div class="form-select"> <select class="form-control" disabled> <option>Disabled select</option> <option>Option</option> </select> </div> </div>
Validation
Add .novalidate to the form-tag and .required to the input elements that should be required.
Also, include the form-validation.php at the bottom of the page.
<form class="needs-validation" novalidate> <div class="form-group"> <label for="input">Input</label> <input class="form-control" type="text" id="input" name="input" required> <div class="invalid-feedback">Invalid</div> </div> <div class="form-group"> <textarea class="form-control" id="textarea" required></textarea> <div class="invalid-feedback">Invalid</div> </div> <div class="form-group"> <div class="form-select"> <select class="form-control" required> <option value="">Default select</option> <option value="1">Option</option> </select> <div class="invalid-feedback">Invalid</div> </div> </div> <div class="form-group"> <div class="form-switch"> <input type="checkbox" id="switchExample3" class="form-control form-control-switch" required> <label for="switchExample3" class="form-label-switch">Default switch</label> <div class="invalid-feedback">Invalid</div> </div> </div> <div class="form-group"> <div class="form-checkbox"> <input type="checkbox" id="checkboxInlineExample3" class="form-control-checkbox" required> <label for="checkboxInlineExample3" class="form-label-checkbox">Default checkbox</label> <div class="invalid-feedback">Invalid</div> </div> </div> <div class="form-group"> <div class="form-radio"> <input type="radio" name="radioInlineExample" id="radioInlineExample4" class="form-control-radio" required> <label for="radioInlineExample4" class="form-label-radio">Default radio 1</label> </div> <div class="form-radio"> <input type="radio" name="radioInlineExample" id="radioInlineExample5" class="form-control-radio" required> <label for="radioInlineExample5" class="form-label-radio">Default radio 2</label> <div class="invalid-feedback">Invalid</div> </div> </div> <button type="submit" class="btn btn-primary">Submit</button> </form> <!-- form-validation.php --> <script> // Example starter JavaScript for disabling form submissions if there are invalid fields (function() { 'use strict'; window.addEventListener('load', function() { // Fetch all the forms we want to apply custom Bootstrap validation styles to var forms = document.getElementsByClassName('needs-validation'); // Loop over them and prevent submission var validation = Array.prototype.filter.call(forms, function(form) { form.addEventListener('submit', function(event) { if (form.checkValidity() === false) { event.preventDefault(); event.stopPropagation(); } form.classList.add('was-validated'); }, false); }); }, false); })(); </script>