当前位置:首页> 正文
关于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就必须别的大,这就跟拼老爸一样,老爸强你就强,这就是传说中的哲学啊。
直接上例子:
复制代码代码如下:
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就必须别的大,这就跟拼老爸一样,老爸强你就强,这就是传说中的哲学啊。
展开全文阅读
相关内容
-
ie与session丢失(新窗口cookie丢失)实测及解决
ie与session丢失(新窗口cookie丢失)实测及解决方案,丢失,新窗...
-
教你通过命令行完美完全的卸载IE浏览器(IE9、IE
教你通过命令行完美完全的卸载IE浏览器(IE9、IE10、IE11),卸...
-
浅析IE10兼容性问题(frameset的cols属性)
浅析IE10兼容性问题(frameset的cols属性),属性,兼容性问题,浏...
-
IE7或者IE8全屏解决方案
IE7或者IE8全屏解决方案,全屏,启用,工具,解决方案,窗口,选项,...
-
原生js方法document.getElementsByClassName在i
原生js方法document.getElementsByClassName在ie8及其以下的...
-
ie6,ie7,ie8完美支持position:fixed的终极解决
ie6,ie7,ie8完美支持position:fixed的终极解决方案,支持,完美...
-
IE6: border的transparent透明解决方案
IE6: border的transparent透明解决方案,解决方案,透明,属性,...
-
ie placeholder属性的兼容性问题解决方法
ie placeholder属性的兼容性问题解决方法,解决方法,属性,失去...
-
IE6,IE7,IE8 css bug搜集及浏览器兼容性问题解
IE6,IE7,IE8 css bug搜集及浏览器兼容性问题解决方法汇总,复...
-
CSS多浏览器兼容性(IE和Firefox)技巧大全推荐
CSS多浏览器兼容性(IE和Firefox)技巧大全推荐,复制,设置,元素...
-
让IE9以下版本的浏览器兼容HTML5的方法
让IE9以下版本的浏览器兼容HTML5的方法,文件,调用,元素,版本,...
-
详解IE浏览器的haslayout属性及相关兼容性问题
详解IE浏览器的haslayout属性及相关兼容性问题解决,属性,浏览...
-
完美兼容IE,chrome,ff的设为首页、加入收藏及保
完美兼容IE,chrome,ff的设为首页、加入收藏及保存到桌面js代...
-
完美兼容ie和firefox的asp.net网站加入收藏和设
完美兼容ie和firefox的asp.net网站加入收藏和设置主页,兼容,...
-
IE.JS解决IE兼容性问题方法汇总
IE.JS解决IE兼容性问题方法汇总,方法,兼容性问题,浏览器,模式...