我在SO上找到的每个问题都列出了z-index修复作为解决方案。不幸的是,这似乎对我没有用。
这是我的结构:
这是CSS
body {
color: #666;
font-size: 12px;
line-height: 18px;
background: url(images/bg-stripes.gif) repeat bottom left;
font-family: "Helvetica Neue", Arial, Helvetica, "Nimbus Sans L", sans-serif;
border: 0;
margin: 0;
padding: 0;
vertical-align: baseline;
}
#wrapper {
position: relative;
margin: 0 auto;
width: 1280px;
padding-top: 30px;
background: transparent;
vertical-align: baseline;
z-index: 0;
}
#main {
position: relative;
clear: both;
overflow: hidden;
padding: 0 0 0 0;
background: #DDD;
z-index: 0;
margin: 0 auto;
width: 1280px;
}
#page-container {
padding: 0 0 0 0;
position: relative;
z-index: 2;
}
#page-background-image {
position: absolute;
left: 0;
top: 0;
width: 460px;
height: auto;
z-index: 1;
overflow: hidden;
}
上面结构中的粗体部分似乎位于主div之后。删除“position:absolute;”从#page-background-image修复问题,但显然删除了绝对位置并搞砸了布局。无论是使用从高到低的索引还是从低到高,为树中的每个元素设置z-index都不会改变。可能还有另一个导致这种影响的问题吗?我宁愿不把它设置为背景图像,因为图像是动态拉动和放置的。
答案 0 :(得分:1)
请务必记住,如果您申请z-index
,则还必须将position
应用为relative
或absolute
。默认情况下,div
设置为static
,因此忽略z-index
。
在#main
上,您已应用z-index
,但未应用position
- 这可能会导致问题。
答案 1 :(得分:1)
原来问题是这个其他div树中有一个浮动div。那个漂浮的div杀死了每个不静止的祖先(直到#main)。解决方案是在浮动div之前立即添加一个空div。