玲儿灵

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

浏览器兼容性问题太让人蛋疼了,今天可是废在了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; 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; } 
//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就必须别的大,这就跟拼老爸一样,老爸强你就强,这就是传说中的哲学啊。

注意:bootstrap在ie7上modal弹出有问题就是这个病瘤所致,解决办法修改553行的代码为:this.$backdrop = a('<div class="modal-backdrop ' + d + '" />').appendTo(this.$body).after(this.$body.find('.modal')), this.$element.on("click.dismiss.bs.modal", 

posted on 2014-11-24 16:09  玲儿灵  阅读(241)  评论(0编辑  收藏  举报