css中的position定位和z-index属性

HTMLDIV设置Z-Index无效http://hi.baidu.com/wjvtoyhdknfghte/item/1f7ddd20aa11120577272c76

http://kuangbaoxu.iteye.com/blog/194437

z-index属性简介

z-index:auto|number

auto:默认值。

number:无单位的整数值,可为负数。

z-index值较大的元素将叠加在z-index值较小的元素之上。对于未指定此属性的定位对象,z-index值为正数的对象会在其之上,而z-index值为负数的对象在其之下。

注意:这个属性不会作用于窗口控件,如select对象。在IE5.5+中,iframe对象开始支持此属性。而在之前的浏览器版本中,iframe对象是窗口控件,会忽略此属性。

z-index属性适用于定位元素(position属性值为relative或absolute或fixed的对象),用来确定定位元素在垂直于显示屏方向(称为Z轴)上的层叠顺序(stackorder)。

每一个定位元素都归属于一个stackingcontext。根元素形成rootstackingcontext,而其他的stackingcontext则由定位元素产生(此定位元素的z-index被定义一个非auto的z-index值),定位子元素会以这个localstackingcontext为参考,用相同的规则来决定层叠顺序。并且stackingcontext和containingblock之间并没有必然联系。

当stackingcontext一样的时候,就用z-index的值来决定怎样显示,如果z-index也相同(即stacklevel相同),则按照档中后来者居上的原则(back-to-front)的顺序来层叠。

当任何一个元素层叠另一个包含在不同stackingcontext元素时,则会以stackingcontext的层叠级别(stacklevel)来决定显示的先后情况。也就是说,在相同的stackingcontext下才会用z-index来决定先后,不同时则由stackingcontext的z-index来决定。例如:

定位元素A(z-index:100)里面有定位元素A1(z-index:300),而定位元素B和元素A兄弟关系(z-index:200)。你会发现无论A1的z-index是多大,也会被z-index是200的B所覆盖,因为A的z-index只有100。

相关推荐