Z-index Not Overlaying Over Divs Further Down In The Dom
Solution 1:
Older IEs kicks off each new positional stack with a z-index of 0 if it's not set (rather than paying attention to a node's parent) -- the result is the last nodes in the markup always obscure earlier nodes.
In order to force older IEs to behave in cases like these, you must define a explicit z-index value for all nodes at the deepest nesting level they all have in common, and they must descend as you move through the document. Once you've done this, you can pull any item from the group ahead of all its peers.
Taking minor freedom with your example to simplify, let's say you had markup like this:
<divclass="container"><divclass="node1"><divclass="child1"></div></div><divclass="node2"><divclass="child2"></div></div><divclass="node3"><divclass="child3"></div></div></div>
You would want to z-index the "nodeX" elements in descending order down the entire page (they must all be at the same nesting level), and then you can give their children z-index values which will make sense.
Your base CSS would be like this:
/* parent nodes in descending order at same nest level */.node1 { z-index: 99; }
.node2 { z-index: 98; }
.node3 { z-index: 97; }
/* child nodes contain tooltip data, z-index higher than parent */.child1 { z-index: 101; display: none; }
.child2 { z-index: 101; display: none; }
.child3 { z-index: 101; display: none; }
... and when you want to display one of the child items as a tooltip, you would need to set its parent z-index above the other parents. In this case we want to activate the tooltip .child2, which lives inside .node2:
.node2 { z-index: 100; }
.child2 { display: block; }
When you set the .node2 to a z-index above all the other ".nodeX" items, it (and its children) should be able to obscure the nodes at the same nesting level.
Automating the Process
This can be a major pain to set up, obviously ... it's simple enough to set a few manual entries on something like a small hardcoded dropdown menu that needs to overlap itself, but if you are dynamically generating the page then you are probably savvy enough to use javascript to help you out.
The important thing is that the descending z-index values must all be at the same nesting level in your DOM tree, I can't stress this enough. To set the descending values for all of our nodeX elements in the example (starting at 99), I might use some jQuery code like this:
$(document).ready( function() {
var zidx = 99;
$('.container>div').each( function() {
$(this).css('z-index',zidx);
zidx--;
});
});
Basically we just loop through elements at the specific level and give each subsequent element a z-index that is one lower. Obviously you'll need to pay attention to how many elements you might use and choose a range accordingly.
Solution 2:
IE incorrectly implements the stacking order algorithm. You'll have to dynamically alter the z-index of the "current" tooltip so whichever is the active .node, give it a z-index of say, 10 and when another tooltip is opened, reassign it to the initial value.
To my knowledge there is no true CSS solution without altering the source order.
Post a Comment for "Z-index Not Overlaying Over Divs Further Down In The Dom"