在CSS中,z-index
属性主要用于管理定位元素(即position
属性值为relative
、absolute
、fixed
或sticky
的元素)的堆叠顺序。元素的z-index
值越大,它就越位于顶层。
注意,z-index
只能应用于相对定位的元素,即position
属性值为relative
、absolute
、fixed
或sticky
的元素。此外,每个元素都有一个默认的z-index
值,通常是0,除非它是一个 positioned元素,在这种情况下,它的默认值是auto。
以下是一些使用z-index
的示例:
/* 示例1 */
.first-element {
position: relative;
z-index: 10;
}
.second-element {
position: relative;
z-index: 5;
}
/* 示例2 */
.container {
position: relative;
}
.first-child {
position: absolute;
z-index: 10;
}
.second-child {
position: absolute;
z-index: 20;
}
/* 示例3 */
.overlay {
position: fixed;
z-index: 1000;
}
在示例1中,即使.second-element
在HTML结构中先定义,由于其z-index
值小于.first-element
,因此.first-element
将显示在.second-element
之上。
在示例2中,即使.first-child
在HTML结构中先定义,由于.second-child
的z-index
值大于.first-child
,.second-child
将显示在.first-child
之上。
在示例3中,.overlay
拥有较高的z-index
值,因此即使它不是最后定义的元素,它也会显示在其他元素之上。
请注意,z-index
只在父元素的z-index
值都相同的情况下才会发挥作用。如果父元素的z-index
值较高,则子元素无论z-index
设置多高都无法显示在其父元素之上。