今天小编跟大家讲解下有关举例详解CSS的z-index属性的使用 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关举例详解CSS的z-index属性的使用 的相关资料,希望小伙伴们看了有所帮助。
通常认为HTML页面是二维的 但实际上 CSS还有一个z-index属性 允许层叠元素。
所有的盒模型元素都处于三维坐标系中。 除了我们常用的横坐标和纵坐标 盒模型元素还可以沿着“z轴”层叠摆放 当他们相互覆盖时 z轴顺序就变得十分重要。
-- CSS 2.1 Section 9.9.1 - Layered presentation默认的摆放规则
假定元素没有指定z-index属性 那么元素按照如下顺序叠放(从底到顶)
根元素的背景和边界 普通流(无定位)里的块元素(没有position或者position:static;)按HTML中的出现顺序堆叠 定位元素按HTML中的出现顺序堆叠
浮动
对于浮动的块元素来说 堆叠顺序变得有些不同。浮动块元素被放置于非定位块元素与定位块元素之间:
根元素的背景与边框 位于普通流中的后代块元素按照它们在 HTML 中出现的顺序堆叠 浮动块元素 常规流中的后代行内元素 后代中的定位元素按照它们在 HTML 中出现的顺序堆叠
使用 z-index
如果需要改变默认的摆放顺序 只需给元素指定z-index。z-index必须是整数 体现了元素在z轴的位置:
底层:距离观察者最远 …… -3 层 -2 层 -1 层 0 层 (默认) 1 层 2 层 3 层 …… 顶层:最接近观察者
没有指定z-index的时候 所有元素默认在0层渲染。多个元素的z-index属性相同时 将按照上文描述的顺序布局。
使用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的元素会构建堆叠上下文。 堆叠上下文可以嵌入其他堆叠上下文。 每个堆叠上下文和它的同级上下文是独立的。 每个堆叠上下文是自包含的。
来源:爱蒂网