How to use vertical-align in CSS

Posted 9 years, 2 months ago at 3:05 am. 3 comments

Poor vertical align still gets a bad rap. While it probably wouldn’t top the list of least used CSS properties (clip may have earned that title), it certainly should get an honorable mention as one of the most avoided and least understood.

I think this is because most coders would expect vertical-align to align an element vertically in its container. Instead it vertically aligns an element in relation to the line-height. For example, #div {vertical-align: middle; } would give us:

Example 1 of vertical align text

While #div {vertical-align: middle; line-height: 2em; } gives us:

Example 2 of vertical align text with line height

To make matters worse, there are other scenarios that may not work as expected. For example:


#exampleContainer {
vertical-align: middle;
line-height: 2em;
width: 200px;
height: 2em;
border: 1px solid red;


<div id="exampleContainer">text<img src="" width="2" height="25" /></div>

This gives us text that is vertically aligned in the middle in the first box, but it isn’t where we wanted it in the second.

Example 3 of vertical align text with line height and image

If we add a vertical-align declaration specifically for the image then we get the intended result with the text.

#exampleContainer img {
vertical-align: middle;

Example 4 of vertical align text with line height and image with line height


  1. Ꮋello, i tһink that i saԝ you visited my bloց so i came to “return tһе favor”.I am trying
    to find things to enhance my website!I suppose its ok to use some of y᧐ur ideas!!

  2. Ꭲhere is definately a lot to find out about this topic.
    I love all the points you have made.

  3. It’s an ɑmazing post designed for all the online viewers;
    they will get benefit from іt І am sure.

Leave a Comment/Question