The Complete Free Guide to Flexbox Practical Examples
Everything you need to know about the most common Flexbox Practical
Examples.
2
What’s the best way to understand Flexbox?
Know the fundamentals, then build lots of stuff. This is the premise upon which this book
is built.
NB: This is not an intro level subject.
If you’re looking for resources to learn css, I recommend the Complete (practical)
Introduction to CSS
A few things to note
1. You don’t have to follow the examples in the order listed here.
2. Flexbox is only a layout technique. Real world projects require more than just
layouts.
3. As a follow up to 2 above, these exercises are also a great way to sharpen
your css skills.
4. When you see a notation such as div.ohans it refers to a div with a class name
of ohans
5. This book has been written with an intermediate developer in mind. i.e you
know a bit about Flexbox.
6. You should start here, if you dont know Flexbox at all.
3
Example 1: How to Make a Photo Gallery with Flexbox
Making photos run in rows and columns with flexbox is easier than most persons perceive.
Consider a simple markup, like so:
<main class=”gallery”>
<img src=”/sample.jpg”>
<img src=”/sample.jpg”>
<img src=”/sample.jpg”>
<img src=”/sample.jpg”>
<img src=”/sample.jpg”>
<img src=”/sample.jpg”>
<img src=”/sample.jpg”>
<img src=”/sample.jpg”>
<img src=”/sample.jpg”>
<img src=”/sample.jpg”>
</main>
Assume the main.gallery has been styled to cover the available screen.
.gallery {
min-height: 100vh
A Quick Note on Images
By default, Images are inline-block elements. They have a width and height. They will
remain on a line except constrained by size i.e the images being too big to fit on a line.
4
The Starting point
Putting everything together, the result of all the markup and style above is this:
Now, get flexbox unto the scene.
.gallery {
display: flex
At this point, the default behaviour of the images is altered. They go from being inline-
block elements to being flex-items
As a result honoring the Flexbox context initiated within .gallery, the images will now be
squashed unto a single line. Plus, they would stretch along the vertical like so:
5
This is as a result of Flexbox’ default behaviour.
1. Squash all child elements unto a single line i.e do not wrap the elements.
This is bad for a gallery, so we change this behaviour like so:
.gallery {
flex-wrap: wrap
This will now wrap the elements i.e. break them unto multiple lines when appropriate.
2. The images now wrap unto the next line but they still stretch along the vertical. We
certainly do NOT want that behaviour as it distorts the images.
The stretch behaviour is owing to the default aling-items value on flex containers.
align-items: stretch
Let’s change that.
.gallery {
...
align-items: flex-start
6
This will keep the images from stretching. They’ll assume their default width and height
values. They will also align to the start of the vertical axis as seen below.
Now we have our flexbox powered gallery.
The Advantage of Using Flexbox
At this point there’s really not much advantage to using Flexbox. We have the same look
we had before initiating the Flexbox model.
Apart from the fact that we get a responsive gallery for free, the other advantages of using
flexbox come from the alignment options Flexbox brings.
Let’s see examples.
Remember that the flex container, .gallery assumes the following preporey values.flex-
direction: row, justify-content: flex-start and align-items: flex-start
The layout of the gallery can be switched in an instant by toying with the default values as
shown below.
.gallery {
...
justify-content:center;
7
As seen in the image above, this will align the images to the center, along the horizontal.
.gallery {
...
justify-content:center;
align-items: center;
8
As seen in the image above, this align the images (horizontally & vertically) to the center
of .gallery
With Flexbox comes a lot of alignment options. Feel free to toy with some more
alignment options as you deem fit.
You may view the actual Flexbox gallery in this codepen.
9
Example 2: How to Build Cards with Flexbox
Cards have become so popular on the internet. Google, Twitter, Pinterest, Everyone is
moving to cards.
A Card is a UI design pattern that groups related information in a flexible-size container. It
visually resembles a playing card.
Here are a few examples.
There are many good uses for cards. A common one is the infamous pricing grid.
Let’s build one.
10
The Markup
Each card will assume a markup like below.
<section class=”card”>
<header>
</header>
<ul>
<li></li>
<li></li>
<li></li>
</ul>
<button></button>
</section>
Pretty simple.
There will be at least 3 cards. Thus, wrap the cards in a div.cards
<div class=“cards”></div>
Now we’ve got a parent element.
For this example, the parent element has been set up to fill the entire viewport.
.cards {
min-height: 100vh
Set up Flexbox
The following code block will initiate a flexbox formatting context within .cards
11
.cards {
display: flex;
flex-wrap: wrap
If you remember from the last example, flex-wrap will allow for the flex-items to break
unto another line.
This happens when the child elements cannot be fitted into the parent element — due to
the larger computed width size of the combined child elements.
Go ahead and give the .card an initial width.
Using flexbox:
.card {
flex: 0 0 250px
This will set the flex-grow and flex-shrink values to 0. The flex-basis value will be set
to 250px
At this point, the cards will be aligned to the start of the page. They will also stretch along
the vertical.
In some cases this may be ideal for your use case. For most, it wont.
12
The Default Behaviour of Flex Containers
The result above is owing to the default behaviour of flex containers.
The cards begin at the start of the page (top left) because justify-content is set to the
value, flex-start .
Also, the cards stretch to fill the entire height of the parent element because align-items is
set to stretch by default.
Altering the default values
We can achieve pretty impressive results by changing the default values that flexbox
offers.
See below.
 align items: flex-start; justify-content: center
 align-items: flex-end; justify-content: center
13
 align-items: center; justify-content: center
To view the final project, see this codepen
14
Example 3: How to Build Grids with Flexbox
Entire CSS frameworks are built on the concept to be discussed in this example.
It is pretty important stuff.
What is a Grid?
In very simple terms, a grid is a made up of a series of intersecting straight (vertical,
horizontal) guide lines used to structure content.
If you’re familiar with CSS frameworks such as Bootstrap, then you sure have used grids
before now.
Your mileage may differ, but we will consider varying grid types in this example.
Let’s start with the first one, basic grids.
1. Basic Grids
Below is a set of basic grids each having equally spaced columns
15
These are grids with the following characteristics.
1. The grid cells should be spaced equally and expand to fit the entire row.
2. The grid cells should be of equal heights.
Thankfully, it is trivially easy to achieve this with Flexbox.
Consider the markup below.
<div class=”row”>
<div class=”row_cell”>1</div>
</div>
Each .row will be its own flex container.
Each element within .row then becomes a flex-item, with all flex items distributed evenly
across the row.
By design, it shouldn’t matter whether we have 3 child elements
<div class=”row”>
<div class=”row_cell”>1/3</div>
<div class=”row_cell”>1/3</div>
<div class=”row_cell”>1/3</div>
</div>
16
Or 6 child elements
<div class=”row”>
<div class=”row_cell”>1/6</div>
<div class=”row_cell”>1/6</div>
<div class=”row_cell”>1/6</div>
<div class=”row_cell”>1/6</div>
<div class=”row_cell”>1/6</div>
<div class=”row_cell”>1/6</div>
</div>
Or 12 elements
<div class=”row”>
<div class=”row_cell”>1/12</div>
<div class=”row_cell”>1/12</div>
<div class=”row_cell”>1/12</div>
<div class=”row_cell”>1/12</div>
<div class=”row_cell”>1/12</div>
<div class=”row_cell”>1/12</div>
<div class=”row_cell”>1/12</div>
<div class=”row_cell”>1/12</div>
<div class=”row_cell”>1/12</div>
<div class=”row_cell”>1/12</div>
<div class=”row_cell”>1/12</div>
<div class=”row_cell”>1/12</div>
</div>
The rules remain the same.
1. The grid cells should be spaced equally and expand to fit the entire row.
17
2. The grid cells should be of equal heights.
The Solution
There are just two steps to doing this.
1. Initiate a Flexbox formatting context.
.row {
display: flex;
2. Have each flex-item expand to fit the entire row — in equal proportions.
.row_cell {
flex: 1
And that’s it.
The Solution Explained.
flex: 1
flex is a shorthand property name for setting three distinct Flexbox properties — the flex-
grow , flex-shrink and flex-basis properties, in the order stated.
flex: 1 only has the value 1 set. This value is attributed to the flex-grow property.
Automagically, the flex-shrink and flex-basis properties will be set to 1 and 0
flex: 1 === flex: 1 1 0
18
You may view the final grid created here.
Grid Cells with Specific Sizes
Sometimes what you want isn’t a grid row of equal cells.
You may want cells that are double the other cells, or any fraction for that matter.
The solution is pretty simple.
To these specific grid cells, add a modifier class like so:
.row_cell--2 {
flex: 2
Also have the class included in the markup. See the first child div in the markup below:
<div class=”row”>
<div class=”row_cell row_cell--2”>2x</div>
<div class=”row_cell”>1/3</div>
<div class=”row_cell”>1/3</div>
</div>
19
The cell with the class .row__cell--2 will be 2x the default cells.
For a cell that takes up 3 times the available space:
.row_cell--3 {
flex: 3
You may see the result of this in this codepen.
Grid Cells with Specific Alignments
Thanks to Flexbox, each cell doesn’t have to tied to a certain alignment value.
You may specify the specific alignment for any cell.
To do so, use modifier classes like this:
.row_cell--top {
align-self: flex-start
This will align the specific cell to the top of the row

applying the .row_cell—-top class will align the specific cell to the top of the row
By the way, you must have added the class to the specific cell in the markup. See the first
child div in the markup below:
20
<div class=”row”>
<div class=”row_cell row_cell--top”></div>
<div class=”row_cell”></div>
<div class=”row_cell”></div>
</div>
Below are the other alignment options available.
.row_cell--bottom {
align-self: flex-end
 applying the .row_cell--bottom class will align the specific cell to the bottom of
the row
.row_cell--center {
align-self: center
21
applying the .row-cell--center class will align the specific cell to the center of the row
Overall Alignment within the Rows
Specific cells can be aligned, so can the entire child elements within the row.
To do this, use a modifier class like so:
.row--top {
align-items: flex-start
It is important to note that the modifier class, .row--top must be added to the row i.e
the parent flex-container
<div class=”row row--top”>
<div class=”row_cell”></div>
<div class=”row_cell”></div>
<div class=”row_cell”></div>
</div>
The other alignment options may be seen below.
.row--center {
align-items: center
22
.row--bottom {
align-items: flex-end
Nested Grids
Without doing anything in particular, these rows can be nested within themselves — to any
degree.
23
 The above image represents a row with two cells, one 2x the other. Within the larger
cell, a row of three centered cells has been nested.
Even More Grids
While you can get fancy building grids with Flexbox (vertical grids and even more
complex configurations), use the best tool for the job. Learn, master and use the CSS Grid
Layout. It is the ultimate CSS solution to Grids.
24
Example 4: How to Build Website Layouts with Flexbox
The community generally frowns upon using Flexbox for full blown web layouts.
While I agree with this, I also think in certain cases you can get away with it.
The single most important advice I can give here would be, use Flexbox where it makes
sense.
I’ll explain the highlighted statement in the following example.
The Holy Grail Layout
What better website layout to build than the infamous “holy grail”?
There are 2 ways to attempt building this layout with Flexbox.
The first is to have the overall layout built with Flexbox. i.e the header, footer, nav,
article and aside all in one flex-container
Let’s begin with that.
The Markup
Consider the basic markup below:
<body>
25
<header>Header</header>
<main>
<article>Article</article>
<nav>Nav</nav>
<aside>Aside</aside>
</main>
<footer>Footer</footer>
</body>
Amongst others, there is a particular rule the holy grail adheres to. This rule has inspired
the markup above.
The center column, article should appear first in the markup, before the two sidebars,
nav and aside
Initiate the Flexbox Formatting Context
body {
display: flex
26
Because the child elements should stack from top to bottom, the default direction of the
flexbox must be changed.
body {
...
flex-direction: column
header and footer should have a fixed width.
header,
footer {
height: 20vh /*you can use pixels e.g. 200px*/
.main must be made to fill the available remaining space within the flex-container
main {
flex: 1
Assuming you didn’t forget, flex: 1 is equivalent to flex-grow: 1 , flex-shrink: 1 and
flex-basis: 0
27
 This will cause main to “grow” and contain the available remaining space.
At this point, we need to take care of the contents within main i.e article, nav and
aside
Set up main as a flex-container
main {
display: flex
}
Have the nav and aside take up fixed widths
nav,
aside {
width: 20vw
Ensure that article takes up the remaining available space
article {
flex: 1
}
There’s just one more thing to do now.
Re-order the flex-items so nav is displayed first.
28
nav {
order: -1
The final result. https://codepen.io/ohansemmanuel/full/brzJZz/
The order property is used to re-order the position of flex-items
All flex-items within a container will be displayed in increasing order values. i.e. the flex-
item with the lowest order values appear first.
NB
By default, all flex-items have a default order value of 0.
The Holy Grail Layout (another solution)
The previous solution used a flex-container as the overall container. The layout is heavily
dependent on Flexbox.
29
Let’s see a more “sane” approach
Take a look at the supposed final result again:
 head and footer could be treated as block elements. Without any intervention, they
will fill up the width of their containing element, and stack from top to bottom.
<body>
<header>Header</header>
<main>
<article>Article</article>
<nav>Nav</nav>
<aside>Aside</aside>
</main>
<footer>Footer</footer>
</body>
With this approach, the only flex-container needed would be main
The singular challenge with this approach is, you have to compute the height of main
30
yourself. This has to be such that main fills the available space (asides the space taken up
by the header and footer)
main {
height: calc(100vh - 40vh);
Consider the code block above, it uses the css calc function to compute the height of
main
Whatever your mileage, the height of main must be equal to calc(100vh — height of
header — height of footer )
Conclusion
As in the previous solution, you must have given header and footer a fixed height. Then
go ahead and treat main the same way as in the previous solution.
You may view the actual results here.
2 column website layouts
Two column layouts are pretty common. They are also easily achieved using flexbox.
31
Consider the markup below:
<body>
<aside>sidebar</aside>
<main>main</main>
</body>
Initiate the Flexbox formatting context:
body {
display: flex;
Give aside a fixed width
aside {
width: 20vw
Finally, ensure that main fills up the remaining available space
main {
flex: 1
That’s pretty much all there is to it.
32
Example 5: Media Objects with Flexbox
Media Objects are everywhere. From tweets to facebook posts, they seem to be the go to
choice for most UI designs.
Consider the markup below:
<div class=”media”>
<img class=”media-object” src=”/pic.jpg”>
<div class=”media-body”>
<h3 class=”media-heading”> Header </h3>
<p></p>
</div>
</div>
As you have guessed, .media will establish the Flexbox formatting context.
.media {
display: flex
33
By default, the flex-items of a container are stretched (along the vertical) to fill the
available height within the flex-container.
Also make sure the .media-body takes up all the remaining available space.
.media-body {
flex: 1
}
See the image above. The box on the left stretch to fit the available screen. The media
body takes up the remaining horizontal space within the media object (white)
Let’s fix the stretched box.
.media {
...
align-items: flex-start
 The flex items are now aligned to the start of the media object. The image now takes it
default’s size. No weird stretching :)
And that’s it.
34
You may find the complete result in this pen.
A flipped Media Object
 A flipped media object has the image on the other side (right) of the media object
You do not have the change the html source order to create a flipped media object
.
Just re-order the flex-items like so:
.media-object {
order: 1
This will have the image displayed after the .media-body and .media-heading
35
A Nested Media Object
You may even go on to nest the Media object. Without changing any of the CSS styles we
have written.
<div class=”media”>
<img class=”media-object” src=”/pic.jpg”>
<div class=”media-body”>
<h3 class=”media-heading”> Header </h3>
<p></p>
<!--nested-->
<div class=”media”>
<img class=”media-object” src=”/pic.jpg”>
<div class=”media-body”>
<h3 class=”media-heading”> Header </h3>
<p></p>
</div>
</div><!--end nested-->
</div>
</div>
It works!
36
A Unicode Media Object
It appears we are not restricted to just images.
Without changing any of the CSS styles written, you can have a unicode represent the
image.
<div class=”media”>
<div class=”media-object”>😎</div>
<div class=”media-body”>
<h3 class=”media-heading”> Header </h3>
<p></p>
</div>
</div>
I have snugged in an emoji there.
 Taking away the img and replacing it with a div containing the desired unicode yields
the output above.
You may grab some more emoji unicodes here, and view the result of this example in this
codepen.
37
An HTML Entity Media Object
You may have also use html entities as seen below.
<div class=”media”>
<div class=”media-object”>☎</div>
<div class=”media-body”>
<h3 class=”media-heading”> Header </h3>
<p></p>
</div>
</div>
The html entity used in this example is ☎ and you may see the result below.
Example 6: How to Build Form Elements with Flexbox
It is difficult to find any website not having a form or two these days.
38
Consider the markup below
<form class=”form”>
<input class=”form__field”>
<button class=”form__item”>…</button>
</form>
<form class=”form”>
<span class=”form__item”>…</span>
<input class=”form__field”>
</form>
<form class=”form”>
<span class=”form__item”>…</span>
<input class=”form__field”>
<button class=”form__item”>…</button>
</form>
This example shows the combination of aligning input fields with buttons or spans of text.
The solution again is quite easy with Flexbox.
Initiate the Flexbox formatting context
.form {
display: flex
Ensure the input field takes up the available space
.form-addon__field {
flex: 1
39
Finally, you may style the appended or prepended texts/buttons whichever way you seem
fit.
.form-addon__item {
...
You may view the complete result of this example in this codepen.
40
Example 7: How to Build a Mobile App Layout with Flexbox
In this example, I will walk you the process the mobile app layout below.
However, this example is different.
I will explain the process of building the mobile layout in pseudo code, and you’ll go
ahead to build it.
This will be a form of practice to get your hands wet.
Step 1 Strip the layout off the iPhone, and we have this:
41
Step 2 Define the containing body as a flex-container
Step 3
By default, the flex-direction of a flex-container is set to row. In this case, change it to
column .
Step 4
Give Item 1 and 3 fixed heights. e.g height: 50px
Step 5
Item 2 must have a height that fills up the available space. Hint: use flex-grow or the flex
shorthand (flex: 1)
42
Step 6
Finally, treat each block of content as a Media Object (as seen in an earlier example)
Follow the six steps above to successfully build the mobile app layout successfully.
Tweet me if you get lost while implementing this example.
Conclusion
In my experience, most UI challenges you’ll faced with will be a variant of one of these
examples.
Go build something cool :)
43
If you loved this free ebook, you can help me.
I published my very first online course in September 2017. Please help recommend it to
anyone you think is struggling with css or looking for a good css resource.
Check it Out
Suggested tweet is “Check out The (Complete) Practical Introduction to CSS by @
OhansEmmanuel
44