html - 如何在图像前面显示菜单项?

标签 html css

我有一个水平导航菜单,当您将鼠标悬停在菜单上时,元素显示在网页图像的后面而不是前面。我该如何解决这个问题?

代码:http://jsfiddle.net/MvWkZ/

HTML:

<div id="nav">
<ul>
    <li><a href="#">Home</a></li>
    <li><a href="#">Tutorials</a>
        <ul>
            <li><a href="#">Photoshop</a></li>
            <li><a href="#">Illustrator</a></li>
            <li><a href="#">Web Design</a>
                <ul>
                    <li><a href="#">HTML</a></li>
                    <li><a href="#">CSS</a></li>
                </ul>
            </li>
        </ul>
    </li>
    <li><a href="#">Articles</a>
        <ul>
            <li><a href="#">Web Design</a></li>
            <li><a href="#">User Experience</a></li>
        </ul>
    </li>
    <li><a href="#">Inspiration</a></li>
</ul>
</div>

CSS:

#nav ul ul {
display: none;
}

#nav ul li:hover > ul {
display: block;
}

#nav ul {
background: #efefef; 
background: linear-gradient(top, #efefef 0%, #bbbbbb 100%);  
background: -moz-linear-gradient(top, #efefef 0%, #bbbbbb 100%); 
background: -webkit-linear-gradient(top, #efefef 0%,#bbbbbb 100%); 
box-shadow: 0px 0px 9px rgba(0,0,0,0.15);
padding: 0 20px;
border-radius: 10px;  
list-style: none;
position: relative;
display: inline-table;
}

#nav ul:after {
    content: ""; clear: both; display: block;
}

    #nav ul li {
float: left;
}
#nav ul li:hover {
    background: #4b545f;
    background: linear-gradient(top, #4f5964 0%, #5f6975 40%);
    background: -moz-linear-gradient(top, #4f5964 0%, #5f6975 40%);
    background: -webkit-linear-gradient(top, #4f5964 0%,#5f6975 40%);
}
    #nav ul li:hover a {
        color: #fff;
    }

#nav ul li a {
    display: block; padding: 25px 40px;
    color: #757575; text-decoration: none;
}

    #nav ul ul {
background: #5f6975; border-radius: 0px; padding: 0;
position: absolute; top: 100%;
}
#nav ul ul li {
    float: none; 
    border-top: 1px solid #6b727c;
    border-bottom: 1px solid #575f6a;
    position: relative;
}
    #nav ul ul li a {
        padding: 15px 40px;
        color: #fff;
    }   
        #nav ul ul li a:hover {
            background: #4b545f;
        }

                    #nav ul ul ul {
position: absolute; left: 100%; top:0;
}

最佳答案

您应该尝试使用 z-index css 属性:

.horizontalmenu{
     z-index:10; /*or more than your image */
     position:relative;
 }

如果您想要更精确的答案,请发布一些代码

编辑:正如 Don 在评论中所说,请务必将菜单放在position:relative(编辑的 css)

关于html - 如何在图像前面显示菜单项?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18984433/

相关文章:

html - 我可以在窗口加载时一次制作一个 css 动画吗?

javascript - 将名称文件(作为变量)分配给 html 元素中的 src 属性

JavaScript 循环问题

html - 我不知道为什么 Flexbox 元素会拉伸(stretch)

javascript - 使用 CSS 或 JavaScript 限制页面大小或限制位置以防止重叠

javascript - 为无序列表 <ul> 中的特定 <li> 元素设置样式

javascript - 如何处理文本以创建带有一些子字符串的新数组?

html - 设置元素的宽度严格等于它的文本内容

javascript - jquery mouseover动态p标签扩展

html - CSS-:hover is slow/laggy in IE7