Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Can't get z-index to work for div inside of another div

I'm trying to get a drop down menu to work. It consists of an LI with a DIV that appears when the LI is hovered. I want the parent to be drawn in front of the child so that I can create a tabbed effect with the overlapping borders. I can't get the child to be drawn behind the parent.

The following code has the same problem:

<div id="test_1">
    Test 1
    <div id="test_2">
        Test 2
    </div>
</div>

And the CSS

#test_1 {
    border:1px solid green;
    width:200px;
    height:200px;
    background-color:#fff;
    position:relative;
    z-index:999;
}

#test_2{
    border:1px solid red;
    width:200px;
    height:200px;
    background-color:#fff;
    position:relative;
    top:-10px;
    left:-10px;
    z-index:900;
}

The above code will draw test_2 in FRONT of test_1. I want test_2 to be drawn BEHIND test_1. How can I get it to do that? Thanks for any help.

like image 520
Cyrcle Avatar asked Dec 15 '10 23:12

Cyrcle


2 Answers

A positioned container always contains its children. You can't have the content of a container below the container itself. See this test file that I made (about 7 years ago) showing the situation.

Note in particular that the dark blue div is z-index:-100, but doesn't appear below its z-index:3 parent container, nor below a different z-index:2 container that is its "uncle" (sibling of its parent).

The z-index of an element is only valid with respect to other elements using the same positioned container. Once you set position:relative on test_1 you are causing its z-index to be in a different world than the z-index of test_2. The closest you can do is set #test_2 { z-index:-1 } to cause it to appear below the content of #test_1 (but not below its background).

like image 147
Phrogz Avatar answered Oct 02 '22 08:10

Phrogz


I can give you a common example about Bootstrap Modals. Consider that your #test_1 is my .modal-body and your #test_2 is my custom <select> box, OK? #test_2 is inside #test_1. Simple as that.

enter image description here

I just have had to make sure #test_1 overflow computed property is not "auto" or "scroll" or "hidden", otherwise, the modal would cut my <select> box listing in the middle. My current .modal-body overflow is initial

like image 36
Matteus Barbosa Avatar answered Oct 02 '22 08:10

Matteus Barbosa