z-index
- 版本:CSS2
- 媒体:视觉
语法:
取值:
- auto:
- 元素在当前层叠上下文中的层叠级别是0。元素不会创建新的局部层叠上下文,除非它是根元素的层叠上下文。
- <integer>:
- 用整数值来定义堆叠级别。可以为负值。
说明:
检索或设置对象的层叠顺序。
- z-index用于确定元素在当前层叠上下文中的层叠级别,并确定该元素是否创建新的局部层叠上下文。
- 每个元素层叠顺序由所属的层叠上下文和元素本身的层叠级别决定(每个元素仅属于一个层叠上下文)。
- 同一个层叠上下文中,层叠级别(即z-index属性值)大的显示在上面,反之显示在下面。
- 同一个层叠上下文中,层叠级别相同的两个元素,依据它们在HTML文档流中的顺序,写在后面的将会覆盖前面的。
- 不同层叠上下文中,元素的显示顺序依据祖先的层叠级别来决定,与自身的层叠级别无关。
- 当z-index未定义或者值为auto时,在IE6,7下会创建新的局部层叠上下文,而在高级浏览器中,按照规范不产生新的局部层叠上下文,如下例:
demo:
div{position:relative;} p{position:absolute;} .a{background:#f00;z-index:10;} .b{background:#0ff;z-index:3;} <div class="test"> <p class="a">asdas</p> </div> <div class="test2"> <p class="b">asdas</p> </div> 细心的你会发现上述代码在IE6,7下的呈现与高级浏览器下不同。.test1和.test2未设置z-index,在高级浏览器下不会产生新的局部层叠上下文,也就是说它们的子元素没有被新的局部层叠上下文包裹,那么它们的子元素就处在同一个层叠上下文中,可以直接通过自身的层叠级别来决定显示顺序,所以结果是.a 覆盖了.b,因为.a的层叠级别比.b高;而在IE6,7下,.test1和.test2会产生新的局部层叠上下文,即它们的子元素被新的局部层叠上下文包裹,于是子元素显示顺序只能依赖.test1和.test2层叠级别来确定。所以结果是.b 覆盖了.a,因为.b的父元素.test2在HTML文档流中排在.test1之后,后来者居上覆盖前者。参见demo: z-index创建局部层叠上下文在IE6,7下与高级浏览器下的区别
- 必须定义position属性值为 relative | absolute | fixed | center | page | sticky,此取值方可生效。
- 对应的脚本特性为zIndex。
兼容性:
- = 支持
- = 不支持
- = 部分支持
Values | IE | Firefox | Chrome | Safari | Opera | iOS Safari | Android Browser | Android Chrome |
---|---|---|---|---|---|---|---|---|
Basic Support | 6.0+ | 2.0+ | 4.0+ | 3.1+ | 4.0+ | 3.2+ | 2.1+ | 4.0+ |
负值 #1 | 4.0+ | 1.0-2.0 | 4.0+ | 3.1+ | 4.0+ | 3.2+ | 2.1+ | 4.0+ |
3.0+ |
- z-index负值是CSS2.1中定义的,在CSS2中是不被支持的;