举例详解CSS的z-index属性的使用

(编辑:jimmy 日期: 2024/10/31 浏览:2)

通常认为HTML页面是二维的,但实际上,CSS还有一个z-index属性,允许层叠元素。

    所有的盒模型元素都处于三维坐标系中。 除了我们常用的横坐标和纵坐标, 盒模型元素还可以沿着“z轴”层叠摆放, 当他们相互覆盖时, z轴顺序就变得十分重要。

-- CSS 2.1 Section 9.9.1 - Layered presentation
默认的摆放规则

假定元素没有指定z-index属性,那么元素按照如下顺序叠放(从底到顶)

    根元素的背景和边界
    普通流(无定位)里的块元素(没有position或者position:static;)按HTML中的出现顺序堆叠
    定位元素按HTML中的出现顺序堆叠
    举例详解CSS的z-index属性的使用

浮动

对于浮动的块元素来说,堆叠顺序变得有些不同。浮动块元素被放置于非定位块元素与定位块元素之间:

    根元素的背景与边框
    位于普通流中的后代块元素按照它们在 HTML 中出现的顺序堆叠
    浮动块元素
    常规流中的后代行内元素
    后代中的定位元素按照它们在 HTML 中出现的顺序堆叠
举例详解CSS的z-index属性的使用

使用 z-index

如果需要改变默认的摆放顺序,只需给元素指定z-index。z-index必须是整数,体现了元素在z轴的位置:

    底层:距离观察者最远
    ……
    -3 层
    -2 层
    -1 层
    0 层 (默认)
    1 层
    2 层
    3 层
    ……
    顶层:最接近观察者

没有指定z-index的时候,所有元素默认在0层渲染。多个元素的z-index属性相同时,将按照上文描述的顺序布局。

使用z-index排序的例子:
举例详解CSS的z-index属性的使用

注意,div#5的z-index无效,因为未指定position属性。
堆叠上下文

指定z-index属性将构造一个堆叠上下文。

以下元素构成堆叠上下文指:

    根元素html
    定位元素,且其z-index值不为auto
    opacity小于1的元素
    在移动WebKit、Chrome22+以上,指定position: fixed的元素总是会构造堆叠上下文,即使z-index为auto。

堆叠上下文中的子元素按照前述顺序摆放。堆叠上下文内部的子堆叠上下文的z-index只在父堆叠上下文中有意义。

总而言之:

    z-index不为auto,opacity小于1的元素会构建堆叠上下文。
    堆叠上下文可以嵌入其他堆叠上下文。
    每个堆叠上下文和它的同级上下文是独立的。
    每个堆叠上下文是自包含的。
举例详解CSS的z-index属性的使用

一句话新闻

高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。