`
天梯梦
  • 浏览: 13730520 次
  • 性别: Icon_minigender_2
  • 来自: 洛杉矶
社区版块
存档分类
最新评论

z-index在IE中的迷惑

阅读更多

今天在写页面的时候发现头部导航栏的下拉菜单,被下面的画中画遮挡住了,然后把导航的下拉菜单样式设置为z-index:999;但是在IE下没起什么作用,而在FF下起作用了。然后又把画中画的样式设置为z-index:-99; 在IE下还是没反映。囧。。。

 

IE下:                                 FF下:
   

 

 

然后在Google里搜索了一下z-index的相关属性,找了半天找到一篇文章。才发现原来又是IE的BUG。。。
解惑: 其实这是 IE 浏览器(windows)的一个 BUG ——在 IE 浏览器中,定位元素会产生一个新的 stacking context,并且从 z-index 的值为 0 开始。



CSS specification 中清楚的规定了除了根元素,只有定位元素的 z-index 被定义一个非 auto 的 z-index 值才能产生新的 stacking context。一般被相对定位的元素并没有定义 z-index,即 z-index 为默认值 auto 。所以按理他不会影响子元素的层叠顺序。而设置了相对定位的 head 产生一个新的 stacking context,所以其被定位的子元素 下拉菜单 以这个新的 stacking context 为参考来决定层叠顺序。



其实IE这个BUG的影响范围很广,只是大家平时不太注意。下面来说明一个最常见的出现情况 z-index 的负值解析,很多朋友因为这个 BUG 的存在甚至武断的认为 IE 支持 z-index 的负值,而FF不支持 z-index 的负值。



我们知道:设置了相对位置(position: relative)的元素但没有给出非 auto 的 z-index 就不会产生 stacking context,也就不会影响其子元素的层叠顺序。所以 下拉菜单 的 stacking context 为根元素产生的 root stacking context。“对于未指定此属性的定位对象,z-index 值为正数的对象会在其之上,而 z-index 值为负数的对象在其之下”,按照规则,应该是设定了 z-index 为-99的 画中画 会显示在于未指定 z-index 属性的元素(比如 body)之下。所以在FF下正常。而在IE中设置了相对位置的 head 会拥有 z-index 值0,产生一个新的 stacking context,下拉菜单 在新的 stacking context 内层叠顺序,故在 IE 中会被遮挡住。

 

z-index可以控制div的显示层级,但是FF和IE对z-index的解析机制不一样。



FF中解析z-index,只要设置div的z-index属性就可以控制了。



IE中解析z-index,不仅要设置div的z-index属性,还必须设置div的父div的z-index属性,这样才可以控制。

 

解决办法:在 head 样式中添加z-index:99; 终于在IE下显示为正常了,FF下也正常。


其实当时我也不是靠这文章说的方法解决的,只是让我知道了原来这是ie bug。

 


<div id=test1></div>

<div id=test2>
<div id=test3></div>
</div>

如果要让test3在test1的上面,那必须这样写

 


<div id=test style="positon:relative;z-index:1 ;"></div>
<div id=test2 style="position:relative;z-index:2 ">
<div id=test3 style="position:absolute; left:0;top:0;"></div>
</div>

关键z-index要写在父div ,


另外,td不能这样写


<td style="position:relative;z-index:2 ">
<div id=test3 style="position:absolute; left:0;top:0;"></div>
</td>

 


IE虽然支持,但FF不支持TD这样写的,必须要加个div或者<span>包起来。

 

 

 

阅读更详细的内容:

 

http://www.w3.org/TR/CSS21/visuren.html#z-index

http://bbs.blueidea.com/thread-2872952-1-1.html

 

 

 

 

 

分享到:
评论

相关推荐

    学习CSS网页制作:z-index在IE中的迷惑.pdf

    本文将深入探讨`z-index`在Internet Explorer(IE)中的表现及其可能带来的迷惑。 `z-index`属性可以设置为`auto`或一个无单位的整数,包括负数。默认情况下,如果未指定`z-index`,元素的值为`auto`。如果`z-index...

    ie6中解决z-index

    在IE6浏览器中,`z-index` 是一个让人头疼的问题,因为它的行为与现代浏览器相比存在差异。`z-index` 属性在CSS中用于控制元素的堆叠顺序,决定哪些元素应该覆盖在其他元素之上。然而,IE6的实现并不完善,导致了...

    z-index为负值的元素无法点击到的解决方法

    在网页布局和设计中,CSS属性z-index常用于控制元素的堆叠顺序。如果一个元素的z-index设置为负值,它将位于所有正常流元素之下,可能导致点击事件无法触发。本文主要讲解在给元素设定负值的z-index后,如何解决该...

    妙用z-index让一个div显示在最前面

    在网页设计中,CSS的z-index属性是用来控制定位元素重叠时的堆叠顺序的。当页面上的元素通过CSS定位属性(如position: relative; position: absolute; position: fixed; position: sticky;)被设定为相对定位、绝对...

    css z-index 在IE中的迷惑

    对于未指定此属性的定位对象,z-index 值为正数的对象会在其之上,而z-index 值为负数的对象在其之下。 注意:这个属性不会作用于窗口控件,如selct 对象。在IE 5.5+中,iframe 对象开始支持此属性。而在之前的...

    margin 负值引起的层级(z-index)问题

    在现代网页设计中,CSS属性z-index用于控制页面元素的堆叠顺序,即层叠上下文。一个元素的z-index值决定了它在页面上的“高度”,或者说是显示层级,拥有更高z-index值的元素会覆盖那些具有较低z-index值的元素。...

    css里的z-index的使用

    1. **IE6/IE7中的元素问题**:在IE6/IE7中,元素的z-index值总是比其他元素高,即使它的z-index值设置得更低。这可能导致元素覆盖其他元素,即使其他元素的z-index值更高。 2. **IE6/IE7中的层叠上下文问题**:IE6...

    CSS教程:网页布局定位及z-index解释

    在提供的压缩包文件中,`z-index-ie.html`和`z-index.html`可能是关于`z-index`属性在不同浏览器(尤其是IE)中的实现和兼容性的示例或教程。IE浏览器在处理`z-index`时可能存在一些特定的问题,比如早期版本对`...

    jQuery中使用插件解决ie6下selectfqg元素设置z-index无效的问题!

    本文将重点讨论如何利用jQuery插件来解决在Internet Explorer 6(IE6)浏览器中遇到的一个常见问题:当尝试为`&lt;select&gt;`元素设置`z-index`属性时,该设置往往无效,导致元素无法正确地覆盖其他内容。这个问题在现代...

    ie6 z-index不起作用的完美解决方法

    然而,在IE6浏览器中,即使设置了很高的z-index值,有时元素仍然无法正确显示在预期的层叠级别之上。 首先,我们必须了解z-index属性的工作原理。z-index只有在元素的position属性被设置为relative、absolute或...

    IE6之Select的Z-Index設定【解决IE6的z-indexBUG】

    在IE6的環境下,如果網頁上有div區塊和下拉選單重疊在一起的時候,即使再怎麼調整下拉選單的z-index,下拉選單還是會把div區塊蓋住(在Firefox是正常的),google了一下網路上的資料,大多是用iframe來解這個問題,但...

    PHP 百度编辑器UEditor自定义层级z-index(层次太高).rar

    在CSS中,z-index是控制元素在垂直于屏幕方向上的堆叠顺序的属性。一个具有更高z-index值的元素将覆盖其下方z-index较低的元素。当元素在同一父容器内并且position属性不是static时,z-index才生效。 UEditor作为一...

    chrome中position:fixed对z-index的影响

    dom结构:正常的实现方式很容易:因为B本身就在A的后面,当A和B都设置了position属性(非static),且没有设置z-index的时候,其层叠关系是后面的元素覆盖前面的元素,这样只需要给A-child设置z-index属性值即可。...

    CSS--z-index详解1

    `z-index`属性在CSS中扮演着至关重要的角色,它定义了元素在页面上的堆叠顺序。简单来说,`z-index`越高,元素越会在其他元素之上显示。但这个规则并非总是如此,理解其工作原理对于创建具有复杂层次的网页布局至关...

    z-index的学习.zip

    在网页设计和开发中,`z-index`是一个至关重要的CSS属性,它决定了元素在层叠上下文中的堆叠顺序。`z-index`的学习是前端开发者必须掌握的核心技能之一,尤其对于创建交互式、多层元素的网页至关重要。下面将详细...

    stylelint-z-index-value-constraint:用于设置z索引的最小和最大约束值的Stylelint规则

    stylelint-z-index-value-constraint 用于设置z索引的最小和最大约束值的Stylelint规则。 这是插件的分支。 安装 npm install stylelint-z-index-value-constraint --save-dev 或者 yarn add stylelint-z-index-...

    Z-Stack 3.0.2-.7z.zip_Z-STACK 3.0.2_Z-STACK-3.0.2_z-stack 3_z-st

    在Z-Stack 3.0.2版本中,有以下几个关键知识点: 1. **网络层优化**:Z-Stack 3.0.2 对网络层进行了优化,提高了网络的稳定性和可靠性,尤其是在处理大量节点的网络中。它改进了路由算法,确保数据包更有效地在网络...

    css中z-index属性实例分析

    - `z-index`属性用于设置或检索层叠上下文中的层叠级别,即元素在页面中的堆叠顺序。 - 层叠上下文是指一组具有相同或不同`z-index`值的元素组成的层级关系。 2. **语法**: - `z-index`的值可以为正整数、负...

    div层调整z-index属性无效原因分析及解决方法

    第二种无效情况是在IE6及IE7浏览器中,z-index的层级表现不完全按照子标签的z-index值高低来决定,而是受到整个DOM树结构的影响。在这些浏览器中,即使子元素的z-index值很高,如果其父元素所在的层级较低,则子元素...

Global site tag (gtag.js) - Google Analytics