理解 CSS 的 z-index 属性

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

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

-- CSS 2.1 Section 9.9.1 - Layered presentationide

默认的摆放规则

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

  1. 根元素的背景和边界
  2. 普通流(无定位)里的块元素(没有position或者position:static;)按HTML中的出现顺序堆叠
  3. 定位元素按HTML中的出现顺序堆叠

浮动

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

  1. 根元素的背景与边框
  2. 位于普通流中的后代块元素按照它们在 HTML 中出现的顺序堆叠
  3. 浮动块元素
  4. 常规流中的后代行内元素
  5. 后代中的定位元素按照它们在 HTML 中出现的顺序堆叠

使用 z-index

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

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

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

使用z-index排序的例子:htm

注意,div#5的z-index无效,由于未指定position属性。排序

堆叠上下文

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

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

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

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

总而言之:

  • z-index不为autoopacity小于1的元素会构建堆叠上下文。
  • 堆叠上下文能够嵌入其余堆叠上下文。
  • 每一个堆叠上下文和它的同级上下文是独立的。
  • 每一个堆叠上下文是自包含的。


原文 Understanding CSS z-index
节译 SegmentFault

相关文章
相关标签/搜索