我在顶部导航上有一个z-index问题,菜单及其子菜单,我希望菜单重叠子菜单,我设置菜单的z-index高于子菜单,但它不是工作子菜单是默认重叠菜单。
请参阅并建议任何可行的方法。
HTML
<div id="login">
<ul>
<li id="overlap"><a href="#">Log In | Join</a>
<ul class="tsm">
<li><a href="#">Log In</a></li>
<li><a href="#">Join</a></li>
</ul>
</li>
</ul>
</div>
CSS
#login {
margin: 0px auto;
width: 1000px;
height: 38px;
background: #343438;
}
#login ul {
float: right;
margin: 0px;
padding: 0px;
width: auto;
height: 38px;
}
#login ul li {
float: left;
width: auto;
height: 34px;
display: inline;
list-style-type: none;
}
#login ul a {
color: #FFF;
display: block;
width: auto;
height: 34px;
font: bold 16px/34px "Arial Narrow", Arial, sans-serif;
text-decoration: none;
text-align: center;
padding: 0px 15px;
text-shadow: 0px -1px #000;
}
#login .tsm {
padding: 20px;
background-color: #F2F2F4;
width: 230px;
height: auto;
text-align: left;
border: 4px solid #777;
position: absolute;
visibility: hidden;
top: 32px;
right: 0px;
z-index: 100;
}
#login .tsm li a {
width: 230px;
height: 30px;
margin-bottom: 1px;
text-align: left;
padding: 0px;
text-decoration: none;
color: #000;
text-shadow: 0px 1px #fff;
font: 15px/30px Arial, sans-serif;
border-bottom: 1px solid #DDDDDF;
}
#login ul #overlap {
position: relative;
border: 2px solid #900;
z-index: 1000;
}
#login ul li:hover .tsm {
visibility: visible;
}
#login ul ul li {
border: none;
}
答案 0 :(得分:2)
问题源于这样一个事实,即你试图将父母置于其子女之上,这会导致问题 - 如果父母向上移动一个级别,那么它的孩子也是如此。您不需要对父列表进行z索引,而是需要对登录链接(标记)进行z索引:
代码很粗糙,但应该让你开始。
确保为链接添加背景颜色,否则您仍然可以看到它。