Difference between align-items and align-content in Flexbox
In my last post, I discussed justify-content
. Today, I will talk about the difference between align-items
and align-content
.
Below, I have some divs (flex-items) inside a container div (flex-container) in an HTML document. The CSS style is also given below.
<div class="container">
<div class="box box1">1</div>
<div class="box box2">2</div>
<div class="box box3">3</div>
<div class="box box4">4</div>
<div class="box box5">5</div>
<div class="box box6">6</div>
</div>
.box {
color:white;
font-size: 100px;
text-align: center;
text-shadow:4px 4px 0 rgba(0,0,0,0.1);
padding:10px;
}
/* Colours for each box */
.box1 { background:#1abc9c;}
.box2 { background:#3498db;}
.box3 { background:#9b59b6;}
.box4 { background:#34495e;}
.box5 { background:#f1c40f;}
.box6 { background:#e67e22;}
.container {
display: flex;
border: 10px solid #000000;
}
data:image/s3,"s3://crabby-images/090c4/090c4db882d80a8868f57196326e2e2b891ead1a" alt=""
align-items
align-items
is used to align flex-items along the cross axis in a flex-container. The default direction of cross-axis is from top to bottom. You must be thinking that to center the flex-items vertically we can set align-items
to center
and you are right but there is a catch! Let us find it out by setting align-items
to center
and see the output.
.container {
display: flex;
border: 10px solid #000000;
align-items: center;
}
data:image/s3,"s3://crabby-images/b84d4/b84d47774361d1ff41df224babf1c5bfdc04cc17" alt=""
What is wrong with the output? It should have been vertically centered but it is not. Why? The answer to this question is hidden in the definition of align-items
. It aligns the flex-items along cross-axis but only inside its flex-container. The black border shows us the height of the container, which is same as the height of flex-items. That is why we see no change. Let’s change the height of the container and see what happens.
.container {
display: flex;
border: 10px solid #000000;
align-items: center;
height: 100vh;
}
data:image/s3,"s3://crabby-images/bf96d/bf96d885b749d961bccecb15b62c03f59e51ccaa" alt=""
Now that align-items: center
is working, let us try other values of align-items. The other possible values of align-items
are flex-start
, flex-end
, stretch
, and baseline
.
data:image/s3,"s3://crabby-images/0f534/0f534ff8a3d5c6aeedbc4c1e2fb2dc75c33d35f2" alt=""
data:image/s3,"s3://crabby-images/52ecc/52ecc5e685827ecf5f1298fa66ac44d93b09dc3e" alt=""
Setting align-items
to stretch
will stretch all the flex-items to take the full height of container. It is also the default value for align-items
. The output can be seen below:
data:image/s3,"s3://crabby-images/b222f/b222fe9175b00addb248c052f82472089fccbd61" alt=""
To explain baseline
, I am changing height and padding of box 3.
.box3 {
padding-top: 50px;
height: 300px;
}
In baseline
, flex-items are algined as their baselines align as seen below:
data:image/s3,"s3://crabby-images/89e27/89e27c49fbf8d7854cdb8c4f1f081cd45434979f" alt=""
align-content
align-content
is a bit tricky. First of all, it only works for multiline flex-items. So, we will have to wrap the flex-items. align-content
deals with the extra space along cross-axis just like justify-content
does for main-axis. First, let us make the necessary changes in CSS to understand align-content
.
.container {
display: flex;
border: 10px solid #000000;
height: 100vh;
flex-wrap: wrap;
}
.box {
width: 33.333%
}
The default value of align-content
is stretch
which stretches flex-items to take full space of the flex-container. In the output below, each row is taking 50% of total container height because there are two rows.
data:image/s3,"s3://crabby-images/8b20f/8b20fd3914fada1104841969b90c01a66f795bf0" alt=""
The other possible values of align-content
are flex-start
, flex-end
, center
, space-between
, and space-around
. The output for each of these is given below:
data:image/s3,"s3://crabby-images/07cad/07cad2edfb7bd99202fed2ffe54f57c0eb96260f" alt=""
data:image/s3,"s3://crabby-images/00648/00648fae2bf192828ffaf07517140cea62490bac" alt=""
data:image/s3,"s3://crabby-images/9d015/9d0152f21399de2a7f638fd0d765bbdabe070b1c" alt=""
data:image/s3,"s3://crabby-images/2197c/2197c670f304db98947efce8ccd52d22b1fd5093" alt=""
data:image/s3,"s3://crabby-images/20553/20553649188fefc93e27db59ae2f92be3d7feaff" alt=""
This is all about align-items
and align-content
in Flexbox. Thanks for reading!