Introduction
Bootstrap is a major CSS framework that has become ubiquitous in modern web development. It provides a collection of HTML and CSS patterns that enable fast and reliable development of responsive styles.
Before Flexbox and CSS Grid, achieving responsive layouts was difficult and time-consuming. Bootstrap offered a simple syntax using class names to allow for responsive designs to be achieved without any custom CSS being required.
It has been particularly popular for those creating an MVP
or Minimal Viable Product, as it frees up development time that would otherwise be spent on styling. Due to its widespread popularity, many companies adopted this package as the foundation for their applications. This meant they could hire developers with experience with Bootstrap and would not need to retrain them on the companies’ custom CSS assets.
Since its inception, Bootstrap has undergone five major version changes. Each major version represents breaking changes
from the last, this is crucial to remember when working with packages such as Bootstrap. Each major version of a package will come with new documentation, as well as new features and improvements.Knowing your version number will help you find the correct documentation.
Each lesson in the CSS Frameworks course includes a practical lesson task related to the study material. We highly recommend attempting each task and then comparing your attempt to the supplied example answer. The more you code, the quicker you will improve.
Installing Bootstrap
There are two ways to use Bootstrap in your projects:
- Using
npm
to install Bootstrap as adependency
. - Using a
cdn
link to include Bootstrap in your project.
From these two options, each has its own advantages. If you do not intend to customise Bootstrap, it is quicker to use the cdn
approach. If you intend to customise Bootstrap styles, to change the theme colour scheme for example, then you should use npm
to install.
Installing with Node Package Manager (NPM)
We recommend that you use Node Version Manager (NVM) for Windows or Node Version Manager (NVM) for Mac OS to manage your NodeJS installations.
- Open your terminal and navigate to your project folder. The easiest way to ensure this is to use the terminal in VS Code, which will automatically open your current working folder.
- In your terminal, run
node --version
to check if NodeJS has been successfully installed. In return, you should get the version of node installed. - Run
npm init -y
to create a new node app, and that will create apackage.json
file if you don’t already have one. - Add Bootstrap version 5.3.3 as a dependency to your project using the command below:
npm install bootstrap@5.3.3
If this is successful, you should find Bootstrap added as a dependency in the package.json
file, and you should also find a Bootstrap directory inside the node_modules
folder inside your project.
Link Bootstrap to the HTML file in the head tag.
<link rel="stylesheet" href="node_modules/bootstrap/dist/css/bootstrap.min.css" />
We will discuss using SASS to customise Bootstrap in a later lesson.
Using a CDN link
If you do not need to customise Bootstrap, you can find the available CDN links here: Bootstrap CDN links.
These will be included in your HTML <head>
like so:
<link
href="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/css/bootstrap.min.css"
rel="stylesheet"
integrity="sha384-QWTKZyjpPEjISv5WaRU9OFeRpok6YctnYmDr5pNlyT2bRjXh0JMhjY6hW+ALEwIH"
crossorigin="anonymous"
/>
<script
defer
src="https://cdn.jsdelivr.net/npm/bootstrap@5.3.3/dist/js/bootstrap.bundle.min.js"
integrity="sha384-YvpcrYf0tY3lHB60NNkmXc5s9fDVZLESaAA55NDzOxhy9GkcIdslK1eN7N6jIeHz"
crossorigin="anonymous"
></script>
Building with Bootstrap
The main difference between an application built with Bootstrap and with custom CSS styles is that most of the styling can be done using provided Bootstrap classes. Generally speaking, there should only be a small amount of custom CSS when working with Bootstrap, as the utility classes provided by the framework are pretty comprehensive.
Layout with Bootstrap
One of the reasons many people choose Bootstrap is how easy it is to create responsive layouts. Bootstrap uses Flexbox and pre-written breakpoints to make layout easy.
To understand and use Bootstrap layout well, one needs to understand some Bootstrap concepts such as Grid System, Containers, Columns, Rows, Breakpoints etc
The Grid System
According to bootstrap, the grid system is a powerful mobile first flexbox grid that can be used to build layouts of all shapes and sizes thanks to a twelve column system, five default responsive tiers, Sass variables and mixins, and dozens of predefined classes. It is built with CSS Flexbox.
To use the grid system, one needs to familiarize himself to a number of predefined classes. See the example below:
<div class="container">
<div class="row">
<div class="col-md-4">Column 1</div>
<div class="col-md-4">Column 2</div>
<div class="col-md-4">Column 3</div>
</div>
</div>
In summary, the code snippet above creates a responsive layout with three columns centered horizontally in the middle of screens ranging from medium to extra-large size. While the container
class provides a structured layout and responsive spacing around your content, the row
class creates 12 columns, and the col-md-4
allocates four columns per div.
Bootstrap divides the page into 12 columns. We can specify how many columns each element takes up and, importantly for responsive websites, how many columns it takes up at various screen widths using the bootstrap breakpoints.
The 12 column structure is used because it offers a great variety of layouts, for example, 3 items of 4 columns, or 2 items of 6 columns, and so on.
Containers
Containers are the basic building blocks of building a responsive layout with Bootstrap and are created using the container
class. There are two main types of containers in Bootstrap:
.container
.container-fluid
- Responsive Container
.container
The .container
class creates a fixed-width container that is centered on the page. It provides responsive padding on both sides, ensuring your content doesn’t stretch too wide on larger screens. For example:
<div class="container">
<p>Your content stays in the middle of the page with equal padding left and right.</p>
</div>
.container-fluid
The .container-fluid
class creates a full-width container that spans the entire width of the viewport. It’s suitable for creating fluid, edge-to-edge layouts. For Example:
<div class="container-fluid">
<p>Your content spans the entire width</p>
</div>
Responsive Containers
These are containers with a breakpoint specifying a layout that is 100% wide until the specified breakpoint is reached, after which we apply max-widths for each of the higher breakpoints. For example:
<div class="container-sm">100% wide until small breakpoint</div>
<div class="container-md">100% wide until medium breakpoint</div>
<div class="container-lg">100% wide until large breakpoint</div>
<div class="container-xl">100% wide until extra large breakpoint</div>
<div class="container-xxl">100% wide until extra extra large breakpoint</div>
Breakpoints
Breakpoints are customizable widths that determine how your responsive layout behaves across device or viewport sizes in Bootstrap.
Here is a list of Bootstrap’s breakpoints.
Breakpoint name | Class infix | Default dimensions |
---|---|---|
Extra small | None | <576px |
Small | sm | >= 576px |
Medium | md | >= 768px |
Large | lg | >= 992px |
Extra large | xl | >= 1200px |
Extra extra large | xxl | >= 1400px |
Rows
The next element we will need in our Bootstrap layout is a row which is created with the row
class. This will be used to group columns together. A row implicitly has 12 columns on which content can be laid out.
<div class="container">
<div class="row">// Columns go here</div>
</div>
Columns
And finally, columns are used to set how many columns each item takes up and uses the col
class.
<div class="container">
<div class="row">
<div class="col">// Column content goes here</div>
</div>
</div>
To determine how many columns each column should take up, you can add a number to the col
class. For example, col-2
would set the column to take up two of the twelve columns for that row. If your total number of columns per row exceeds 12, it will wrap onto a new line.
<div class="container">
<div class="row">
<div class="col-8">// Column content goes here</div>
<div class="col-4">// Column content goes here</div>
</div>
</div>
In the above example, the first col
element would take up 8 columns, and the second col
element would take up 4 columns, but this would only be on mobile. Working mobile-first, we can add how many columns an element should take up at specific breakpoints. For example, col-sm-6
would set an element to take up 6 columns on small devices (sm
for small).
<div class="container">
<div class="row">
<div class="col-6 col-sm-7 col-md-8 col-xl-9">// Column content goes here</div>
<div class="col-6 col-sm-5 col-md-4 col-xl-3">// Column content goes here</div>
</div>
</div>
In the above example, the first and second columns would be equal-sized on mobile. On small devices, the first column will take up 7 columns, and the second column 5 columns. Then on medium devices 8 and 4 columns, respectively, and on extra large devices, they’ll take up 9 and 3 columns.
Watch the following video showing the basics of laying out a page with Bootstrap: Introduction to layout with Bootstrap (4m 59s).
You can read more about layout here: Bootstrap Breakpoints.
Bootstrap Classes
Bootstrap exposes its functionality via a system of CSS Classes. These can be combined in various ways to build many different layouts. Within Bootstrap, there are Utility
and Component
classes available:
Utility Classes
One of the most important features of Bootstrap is the provision of Utility Classes
which can be used to avoid writing custom CSS for common tasks.
You can read more about the utility classes here: Bootstrap Utility Classes.
Spacing
When managing margins, padding and gaps (spacing) for HTML elements, there is a suite of classes that can be used to keep these values consistent:
.m-0 > No margin on all sides
.m-1 > Smallest margin on all sides
.m-2 > Small margin on all sides
.m-3 > Medium margin on all sides
.m-4 > Large margin on all sides
.m-5 > Largest margin on all sides
As well as -<number>
suffixes that control margin sizing, the location of the padding can also be controlled:
.mt-1 > Smallest margin on top
.mb-2 > Small margin on bottom
.my-3 > Medium margin on top and bottom
.mx-4 > Large margin on left and right
In Bootstrap, left
and right
are referred to as start
and end
, respectively. This ensures that the syntax makes sense to users that read from left to right (LTR) as well as right to left (RTL).
.ms-1 > Smallest margin at start (left)
.me-2 > Small margin at end (right)
You can read more about spacing utility classes here: Spacing Utility Classes.
Flexbox
Bootstrap is built with flexbox and provides direct access to flex styles through a system of classes.
.d-flex > Display flex
.flex-column > Arrange as a column
.flex-row > Arrange as a row
.flex-wrap > Wrap items
.flex-nowrap > Do not wrap items
.justify-content-center > Centre align items along the main axis
.align-items-center > Centre align items along the cross axis
For example, to centre align items on both axes, you can use the following classes:
<div class="d-flex align-items-center justify-content-center">
<div class="border p-5">Centre</div>
</div>
You can read more about the flexbox system here: Flexbox.
Other utilities
There are many more utility classes that can be used to customise Bootstrap. These include classes to control:
- Text alignment
- Text style
- Font weight
- Font size
- Text colour
- Background colour
- Border
- Shadow
- Position
- Overflow
Before writing custom CSS in a Bootstrap project, it is worth spending some time to research if a Bootstrap class can handle this instead.
Component Classes
Unlike utility classes, which refer directly to a specific style, component classes represent a group of styles used to build a specific component. For example, we may use the btn
component to add styles to an element that the user can interact with:
<div class="btn-group">
<button class="btn btn-primary">Primary</button>
<div class="btn btn-info">Info</div>
<a href="#" class="btn btn-danger">Danger</a>
<input type="reset" class="btn btn-warning" value="Warning" />
<input type="submit" class="btn btn-success" value="Success" />
</div>
All of these classes enable an HTML element to be styled in a consistent way. You can read more about the button component here: Button Component.
Other popular components include:
These component groups form the basis of the Bootstrap framework and should be used like lego blocks to build up a layout.
Lesson task
Brief
For this task, you will create a single-page application that uses Bootstrap. You should not customise Bootstrap in any way or use custom CSS at all.
You can use an existing project, an upcoming or planned project, or a fictional project.
Design a landing page for your project that includes a header, navigation, and footer. The navigation should scroll you to the correct location on the page. Include a form that allows the user to register their interest in your project.
Process
- Design a simple one-page landing page
- Create a new project folder
- Link the CDN Bootstrap CSS and JS files to your HTML
- Use HTML + Bootstrap CDN to build the page