preface

Recently, when using antD’s concatenation widget in a project, I noticed that there is nothing in the text box after selecting the option, but the placeholder is missing, and the x on the far right is displayed when the mouse hovered over the text box. This indicates that the value is present, but it is not displayed on the page, so F12 examines the element and finds that there is indeed something there, as shown in the following figure:

The second element, input, has been set to the position of the result, so this article, re-learn the CSS hierarchy and record.

The hierarchy

In addition to the X and Y axes, there is also a Z axis, which can be understood as the line from the page to the front of the screen

Common elements

Let’s take a look at the hierarchy of common elements as follows:

.less> * {width: 300px;
    height: 300px;
}
.block{
    background: cadetblue;
    margin-top: -350px;
    margin-left: 10px;
}
.inline{
    display: inline-block;
    background: cyan;
    margin-top: 100px;
    margin-left: 100px;
}
.float{
    float: left;
    background: chocolate;
    margin-top: -340px;
    margin-left: 150px;
}
.position{
    position: absolute;
    top: 0;
    left: 250px;
    background: brown;
}
.position2{
    top: -200px;
    left: 60px;
    position: relative;
    background: blueviolet;
    z-index: 1;
}
.position3{
    z-index: -1;
    background: bisque;
    left: 30px;
}
Copy the code
<div class="less">
    <span class="inline">inline</span>
    <div class="block">block</div>
    <div class="float">float</div>
    <div class="position">position</div>
    <div class="position2">position2-relative</div>
</div>
Copy the code

The effect is as follows:

Block ->float->inline(-block)->position.

Why didn’t I write position2? All position elements belong to the same level. Position2 is overwritten by position because position2 comes after position in HTML. If position2 and position are replaced, what happens to another block2 after the block?

.block2{
    background: darkorange;
    margin-top: -270px;
    margin-left: 50px;
}
Copy the code
<span class="inline">inline</span>
<div class="block">block</div>
<div class="block2">block2</div>
<div class="float">float</div>
<div class="position2">position2-relative</div>
<div class="position">position</div>
Copy the code

As you can see, elements of the same rank are behind each other based on their position in the HTML.

Z – the index attribute

In addition to the default hierarchy order, you can use the Z-index attribute to change the hierarchy order of elements. Add z-index:1 to the upper position2 element and add a new position3 and z-index:-1 at the end to observe changes at the element level.

As you can see, the element level of -1 is lower than the block element, and the element level of 1 overrides the element without the z-index set. From bottom to top the hierarchy should be position z-index negative ->block->float->inline(-block)-> Positon not set Z-index ->position z-index positive. What happens if you add z-index attributes to other elements? In fact, there is no effect, and the other elements remain in their original level as shown above.

So what elements does the z-index attribute apply to? This article lists some common attributes:

  • An element whose position value is not static
  • Child elements of Flex, Grid
  • Opacity value is less than 1
  • The values of transform and filter are not None

Let’s verify common Flex elements

.flex{
    display: flex;
    border: 1px solid red;
    width: 300px;
    margin: 50px;
}
.flex>div{
    width: 100px;
    height: 100px;
    flex-shrink: 0;
}

.flex0{
    background: blue;
    z-index: 0;
}

.flex-1{
    background: green;
    z-index: -1;
    margin-left: -50px;
    margin-top: -30px;
}

.flex1{
    background: yellow;
    z-index: 1;
    margin-left: -120px;
    margin-top: -60px;
}
Copy the code
<div class="flex">
    <div class="flex0">0</div>
    <div class="flex-1">- 1</div>
    <div class="flex1">1</div>
</div>
Copy the code

And you can see that it does stack up in order of z-index from smallest to largest.

So the final order is: Z-index valid and negative ->block->float->inline(-block)-> Z-index valid and not set -> Z-index valid and positive

Code for this article: CSS hierarchy

Reference: Understand z-index

Here’s a classic CSS hierarchy:

Afterword.

After solving the problem, I went to antD official website to try to set the input to a relative position and found that the selected value was still visible, so the question in my mind was everywhere. Why was our input overwritten? On closer inspection, it turned out that someone had set all the inputs to a pure white inner shadow. I…