手机
当前位置:查字典教程网 >网页设计 > Div+Css教程 >关于IE7 z-index的浏览器兼容性问题完美解决方案
关于IE7 z-index的浏览器兼容性问题完美解决方案
摘要:浏览器兼容性问题太让人蛋疼了,今天可是废在了IE7的z-index问题上。可又不能因为浏览器版本低而不去解决,毕竟要从用户的角度着想。百度了...

浏览器兼容性问题太让人蛋疼了,今天可是废在了IE7的z-index问题上。可又不能因为浏览器版本低而不去解决,毕竟要从用户的角度着想。百度了好多还是无法解决,最后google了一下,找到了方法。

直接上例子:

<div id="container">

<div id="box1">This box should be on top</div>

</div>

<div id="box2">

This box should not be on top;

IE however seems to create a new stacking context for positioned elements,

even when the computed z-index of that element is 'auto'.

</div>

body { margin: 0; padding: 0; }

#container { position: relative;}

#box1 { position: absolute; top: 100px; left: 510px; width: 200px; height: 200px; background-color: yellow;z-index:20; }

#box2 { position: absolute; top: 50px; left: 460px; width: 200px; height: 200px; background-color: lime; z-index: 10;}

这是为什么呢?其实这是IE浏览器的一个BUG——在IE浏览器中,定位元素会产生一个新的stacking context,并且从z-index的值为0开始。所以我们需要在这个元素的父元素上设置一个更高的z-index值。

在上述的box1中的父元素container设置一个更大的z-index就能解决这个问题。

body { margin: 0; padding: 0; }

#container { position: relative; z-index:30;}

#box1 { position: absolute; top: 100px; left: 510px; width: 200px; height: 200px; background-color: yellow; }

//box1有没有z-index都无所谓了,但必须同position(relative或absolute)使用,就跟一个人

//生不了孩子一样,需要配合。

#box2 { position: absolute; top: 50px; left: 460px; width: 200px; height: 200px; background-color: lime; z-index: 20; }

要想覆盖住父级的同级 ,父级的z-index就必须别的大,这就跟拼老爸一样,老爸强你就强,这就是传说中的哲学啊。

【关于IE7 z-index的浏览器兼容性问题完美解决方案】相关文章:

关于DIVCSS浮动float的兼容

Google浏览器CSS居中兼容问题完美解决方法

火狐下easyui1.3.*弹出window框无法定位到中间问题解决

ie placeholder属性的兼容性问题解决方法

firefox中div+css的外层背景色不见的解决方法

比较全的CSS浏览器兼容问题整理总结

ie6,7下空DIV无任何内容时占据空间问题解决

IE.JS解决IE兼容性问题方法汇总

IE6下div层被select控件遮住的问题解决方法

IE与Firefox的CSS兼容大全

精品推荐
分类导航