• Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 1005
  • Last Modified:

CSS IE li:hover z-index

I'm currently having trouble getting a flyout menu in the left navigation to have the proper working z-index in IE. When you roll over plugs, the flyout menu should hover on top of all other items, but it does not in IE. I do realize that IE has a bug in this area, and I've tried 2 javascript fixes but I still can't manage to get it to work! Any help would be appreciated...

The link to the page I'm having trouble with is here:
http://209.162.183.249/
#LEFTNAV {
	margin: 20px 0px 0px 0px;
	float: left;
	width: 15%;
	background-color: #272750;
	-moz-border-radius: 0px 7px 7px 0px;
	-webkit-border-top-right-radius: 7px;
	-webkit-border-bottom-right-radius: 7px;
	border-radius: 0px 7px 7px 0px;
	padding: 10px 10px 10px 0px;
}
 
#LEFTNAV ul {
	position: relative;
	background-color: #cccccc;
	padding: 3px;
	-moz-border-radius: 0px 7px 7px 0px;
	-webkit-border-top-right-radius: 7px;
	-webkit-border-bottom-right-radius: 7px;
	border-radius: 0px 7px 7px 0px;
	margin: 0px;
	list-style: none;
 
}
 
#LEFTNAV ul li a {
	display: block;
	text-decoration: none;
	font-family: Verdana;
	font-size: 11px;
	font-weight: normal;
	color: #000000;
	padding: 1px 0px 1px 10px;
	height: 1%;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #666666;
	}
	
#LEFTNAV ul li a:hover{
	color: #ffffff;
}
 
#LEFTNAV ul li:hover {
	background-color: #666666;
}
 
#LEFTNAV ul Li {
	margin: 1px;
	width: 100%;
}
 
#LEFTNAV .LeftNav_Headers {
	padding: 7px 0px 3px 10px;
	margin: 0px;
}
 
#LEFTNAV ul li.DisplayFlyout ul.FlyoutMenu {
	z-index: 100;
	display: none;
	position: absolute;
	top: 0px;
	left: 150px;
	margin: 0px;
	width: 80px;
}
 
#LEFTNAV ul ul {
	background-color: #cccccc;
	list-style: none;
	border: solid 2px #000000;
	-moz-border-radius: 0px 0px 0px 0px;
	-webkit-border-top-right-radius: 0px;
	-webkit-border-bottom-right-radius: 0px;
	border-radius: 0px 0px 0px 0px;
}
 
#LEFTNAV ul li.DisplayFlyout:hover ul.FlyoutMenu{
	display: block;
	
}
 
 
<ul>
    <li class="DisplayFlyout">
    <a href="http://<%= Request.ServerVariables("server_name") %>/products.asp?jewelry=plugs">Plugs &amp; eyelets</a>
        <ul class="FlyoutMenu">
        <li><a href="http://<%= Request.ServerVariables("server_name") %>/products.asp?jewelry=plugs&gauge=18g">18g</a></li>
        <li><a href="http://<%= Request.ServerVariables("server_name") %>/products.asp?jewelry=plugs&gauge=18g">16g</a></li>
        <li><a href="http://<%= Request.ServerVariables("server_name") %>/products.asp?jewelry=plugs&gauge=14g">14g</a></li>
        <li><a href="http://<%= Request.ServerVariables("server_name") %>/products.asp?jewelry=plugs&gauge=12g">12g</a></li>
        </ul>
    </li>
    <li><a href="http://<%= Request.ServerVariables("server_name") %>/products.asp?jewelry=tapers">Tapers &amp; stretching</a></li>
    <li><a href="http://<%= Request.ServerVariables("server_name") %>/products.asp?jewelry=barbell">Straight barbells</a></li>
</ul>

Open in new window

0
twentythree
Asked:
twentythree
  • 3
  • 3
1 Solution
 
s8webCommented:
The problem may be elsewhere on the page. Check the declarations on the other items on the page. For z-index to work properly, the div that is conflicting has to be absolute positioned with a lower z-index. Without the rest of the code, I can't tell.
0
 
twentythreeAuthor Commented:
Here's a link to the entire page: http://209.162.183.249/
0
 
s8webCommented:
Try putting z-index:50 on leftnav and z-index:100 on leftnav ul and see what happens.
0
Ultimate Tool Kit for Technology Solution Provider

Broken down into practical pointers and step-by-step instructions, the IT Service Excellence Tool Kit delivers expert advice for technology solution providers. Get your free copy now.

 
twentythreeAuthor Commented:
Doesn't work :(
From what I've read online if you're using li:hover rather than a:hover in IE, then it nullifies the ability to use the z-index on the CSS. It's like it doesn't read it or something and you have to resort to using javascript or something to override it.

So far I haven't been able to find any way to fix it. But it seems to be a common bug.
0
 
s8webCommented:
hmm... have you checked out superfish http://users.tpg.com.au/j_birch/plugins/superfish/#examples

There's a class set up for vertical only uses (separate stylesheet). I've used it in a couple places. You can customize it for your situation. It uses the jquery library which is reasonably lightweight in it's compressed form.

It's not the magic bullet, you will have to rework a little (attach classes to your existing <ul> but in the end it will accomplish what you're looking for.
0
 
twentythreeAuthor Commented:
Well it's not quite what I had in mind... but at least it works! Plus it has nicer effects and is pretty fast too... thanks :)
0
Question has a verified solution.

Are you are experiencing a similar issue? Get a personalized answer when you ask a related question.

Have a better answer? Share it in a comment.

Join & Write a Comment

Featured Post

Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

  • 3
  • 3
Tackle projects and never again get stuck behind a technical roadblock.
Join Now