align-items
data:image/s3,"s3://crabby-images/16a67/16a67d74d5547a8b3d10fbde13534ae2120dc0dc" alt="Aligning Flex Items Effortlessly with align-items"
The align-items
property is used to set a layout pattern of flex items (nested child elements) along the cross axis of the flex container. The cross axis is typically the vertical axis unless you set column
or column-reverse
in the flex-direction
property. We'll provide our explanation based on the default flex-direction
setting.
This property is effective when the flex items are placed only in one line. When the flex items are wrapped, you need to add the align-content
property, which will be explained in the next topic.
flex-start
This is the default setting. With this property value, flex items are laid out at the top edge of the parent element.
Note: 'edge' means the endpoint with some distance from the edge of the element based on the container's paddings and flex item's margins.
data:image/s3,"s3://crabby-images/52ec1/52ec1b1af1887a33f11aa3238656b253c4653fbf" alt="align-items: flex-start align-items: flex-start"
center
With this property value, flex items are laid out in the center of the parent element.
data:image/s3,"s3://crabby-images/8a365/8a36521b32640f493798fcc4824719ae015f053f" alt="align-items: center align-items: center"
flex-end
With this property value, flex items are pushed out to the bottom edge of the parent element.
data:image/s3,"s3://crabby-images/1e29d/1e29dcbcb5fd7a5ee096cd31cfb4bada912ee837" alt="align-items: flex-end align-items: flex-end"
stretch
With this property value, flex items are stretched from the top edge to the bottom edge of the parent element.
data:image/s3,"s3://crabby-images/416aa/416aa39d02bd9c2ad608d02ae7249e069eb3a3bd" alt="align-items: stretch align-items: stretch"
baseline
With this property value, flex items are aligned with the flex container baseline like in the image below.
data:image/s3,"s3://crabby-images/70535/70535d0d80d49e8b5b344d0450f1d243529b31fe" alt="align-items: baseline align-items: baseline"
Practice
Objective:
Check how the align-items property works
1. Update the body section of the HTML file
Add the code below in the <body>
section of the chapter15.html file. We use the same classes as the ones set before. There is no need to set new classes.
<h2>align-items</h2>
<h3>Original Position</h3>
<div class="flex-container" style="display: flex; height: 100px;">
<div class="flex-item" style="font-size: 2rem;">1</div>
<div class="flex-item">2</div>
<div class="flex-item" style="font-size:1.5rem;">3</div>
</div>
<h3>align-items: flex-start</h3>
<div class="flex-container" style="display: flex; height: 100px; align-items: flex-start;">
<div class="flex-item" style="font-size: 2rem;">1</div>
<div class="flex-item">2</div>
<div class="flex-item" style="font-size:1.5rem;">3</div>
</div>
<h3>align-items: center</h3>
<div class="flex-container" style="display: flex; height: 100px; align-items: center;">
<div class="flex-item" style="font-size: 2rem;">1</div>
<div class="flex-item">2</div>
<div class="flex-item" style="font-size:1.5rem;">3</div>
</div>
<h3>align-items: flex-end</h3>
<div class="flex-container" style="display: flex; height: 100px; align-items: flex-end;">
<div class="flex-item" style="font-size: 2rem;">1</div>
<div class="flex-item">2</div>
<div class="flex-item" style="font-size:1.5rem;">3</div>
</div>
<h3>align-items: stretch</h3>
<div class="flex-container" style="display: flex; height: 100px; align-items: space-between;">
<div class="flex-item" style="font-size: 2rem;">1</div>
<div class="flex-item">2</div>
<div class="flex-item" style="font-size:1.5rem;">3</div>
</div>
<h3>align-items: baseline</h3>
<div class="flex-container" style="display: flex; height: 100px; align-items: baseline;">
<div class="flex-item" style="font-size: 2rem;">1</div>
<div class="flex-item">2</div>
<div class="flex-item" style="font-size:1.5rem;">3</div>
</div>
<hr>
2. Check the result with a browser
- Open chapter15.html with a browser.
- You can see how the
align-items
property adjusts the positions of the flex items.
You can also check the sample result here (Demo Site).