相对Div内的IE7绝对Div消失了。 z-index不能解决问题

时间:2011-10-05 14:34:01

标签: html internet-explorer-7 position z-index

我在SO上找到的每个问题都列出了z-index修复作为解决方案。不幸的是,这似乎对我没有用。

这是我的结构:

  • div包装器
    • div header
    • div main
      • div page-container
        • div page-background-image
          • div page-bottom-gradient
      • div primary
        • div left-menu
      • div outer-container
      • 等...
    • div footer

这是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都不会改变。可能还有另一个导致这种影响的问题吗?我宁愿不把它设置为背景图像,因为图像是动态拉动和放置的。

2 个答案:

答案 0 :(得分:1)

请务必记住,如果您申请z-index,则还必须将position应用为relativeabsolute。默认情况下,div设置为static,因此忽略z-index

#main上,您已应用z-index,但未应用position - 这可能会导致问题。

答案 1 :(得分:1)

原来问题是这个其他div树中有一个浮动div。那个漂浮的div杀死了每个不静止的祖先(直到#main)。解决方案是在浮动div之前立即添加一个空div。

相关问题