preface

As you know, “How does CSS center elements vertically?” It has been a platitude. There have been many solutions to this problem, and these solutions have their own applicable scenarios and advantages and disadvantages, which are roughly as follows:

  • Flex layout
  • The grid layout
  • The table layout
  • The line height match height
  • The position match the margin
  • The position match the transform
  • .

So today we will understand the principle of one of the effective but not often used schemes, which is: pseudo-element :before

<style type="text/css">
  .parent {
    display: inline-block;
    width: 300px;
    height: 300px;
    font-size: 0;
    background: #80848f;
    text-align: center;
  }
  .parent:before {
    display: inline-block;
    width: 20px;
    height: 100%;
    content: ' ';
    background: #ff9900;
    vertical-align: middle;
  }
  .child {
    display: inline-block;
    width: 50px;
    height: 50px;
    background: #19be6b;
    vertical-align: middle;
  }
</style>

<div class="parent">
  <div class="child">child</div>
</div>
Copy the code

The code above runs like this:

I’m sure the code is familiar, but do you really understand how it works? So let’s look at how it works and how it works to get vertically centered, right

Analysis of the

It is important to remember that the location of the parent element, the baseline, can be changed. It is not fixed

Next, we streamlined the code to get rid of key parts

<style type="text/css">
  .parent {
    display: inline-block;
    width: 300px;
    height: 300px;
    /* font-size: 0; * /
    background: #80848f;
    text-align: center;
  }
  .parent:before {
    display: inline-block;
    width: 20px;
    height: 100%;
    content: ' ';
    background: #ff9900;
    /* vertical-align: middle; * /
  }
  .child {
    display: inline-block;
    width: 50px;
    height: 50px;
    background: #19be6b;
    /* vertical-align: middle; * /
  }
</style>

<div class="parent">
  <div class="child">child</div>
</div>
Copy the code

Font-size :0; vertical-align:middle;

For :before pseudo-element, vertical-align:middle, the result is the same, it will always fill the parent element in the vertical direction; But for the.child element, it changes its vertical position, so why is that?

The purpose of this pseudo-element is to change (or redefine) the position of the parent element baseline. Let’s review the definition of vertical-align:middle in the MDN document

Middle: aligns the middle of the element with the baseline of the parent element plus half of the x-height of the parent element

So, compare our example:

  • The middle of a pseudo-element is its vertical midpoint, which is understandable
  • The base line of the parent we don’t care where it is, but it’s enough to remember that it can change, right
  • Because we set font size to 0 in the parent element, half of x-height is also 0, i.e. there is no height

So if you do that, it’s like the midpoint of the pseudo-element as long as it’s aligned with the base line of the parent element, because x-height is 0, so it doesn’t matter whether you add or leave it; In addition, Css elements are aligned in the upper left by default. This constraint means that by default, when a pseudo-element is aligned with vertical-align:middle, it will not be displayed outside the parent element. Then the pseudo-element height has been determined: 100% of the parent element height, and the midpoint has been determined

The pseudo-element then says to the parent: My vertical midpoint is fixed, and I can’t change it, for the rest of my life, but I want my midpoint to align with your baseline, so it’s up to you

The parent element then compromises and moves its own baseline to a position aligned horizontally with the midpoint of the pseudo-element, where the parent element baseline is also determined to be approximately half its height

Finally, the child element adds its own vertical-align:middle, according to middle: Align the middle of the element with the base line of the parent element plus half of the x-height of the parent element. The font size of the.child element is aligned with the base line of the parent element and half of the x-height of the parent element

conclusion

In fact, the principle of this vertical centering mode mainly has the following points:

  • Elements in Css are aligned in the upper left by default
  • The pseudo element height is consistent with the parent element
  • The parent element sets font size to 0, which in turn sets x-height to 0
  • The position of the parent element baseline can be changed

Once we understand the principles, we don’t have to memorize code or forget how to implement it; If there are any mistakes in this article, please correct them

Which is your favorite solution to this common problem of vertical center? Please leave a comment

About us