CSS堆叠上下文
前言:设置了z-index:9999;
的层叠顺序一定高于z-index:0;
吗?很明显这句话在某些情况下是不成立的,而引起其不成立的原因就是堆叠上下文的现象。本文主要介绍关于css中堆叠上下文的概念、引起的原因等。
注:友情链接:关于堆叠上下文的MDN介绍,张鑫旭的博客《深入理解CSS中的层叠上下文和层叠顺序》
1、什么是堆叠顺序
从最底层到最高层的顺序如下:
- 父级元素的background
- 父级元素的border
- 块级子元素
- 浮动元素
- 父元素的文字或内联子元素
- 定位元素z-index: 0
- 定位元素z-index: +
其中,负的z-index出现的位置有两种可能:
- 父元素是
position:static;
时:负的z-index出现在0号位(即1.父元素的background的底下一层) - 因一些原因导致了层叠上下文现象出现时,负的z-index出现在2号位与3号位的中间,即只要出现了层叠上下文,子元素的
z-index
即使是负的,也会出现在父元素的上边。
2、层叠上下文出现的原因
- 根元素 (HTML),
- z-index 值不为 “auto"的 绝对/相对定位,
- 一个 z-index 值不为 “auto"的 flex 项目 (flex item),即:父元素 display: flex|inline-flex,
- opacity 属性值小于 1 的元素(参考 the specification for opacity),
- transform 属性值不为 “none"的元素,
- mix-blend-mode 属性值不为 “normal"的元素,
- filter值不为“none”的元素,
- perspective值不为“none”的元素,
- isolation 属性被设置为 “isolate"的元素,
- position: fixed
- 在 will-change 中指定了任意 CSS 属性,即便你没有直接指定这些属性的值(参考 这篇文章)
- -webkit-overflow-scrolling 属性被设置 “touch"的元素
3、我对层叠上下文现象的理解
假设有两个部门,分别是【甲】和【乙】,【甲】在前,【乙】在后,正常情况下,【甲】【乙】中的职员的地位由z-index
决定,z-index
相同的时候,【乙】中职员级别比【甲】高;而当出现了层叠上下文现象时,就相当甲、乙两个部门的负责的项目发生了变化,假如【甲】负责一个是千万级的项目,【乙】负责的是日常十万级别的项目,所以最终【甲】中的职员,哪怕在部门中的地位再低(即z-index:0
),获得的薪酬也会比【乙】部门中的职员包括部门leader(即z-index:9999
)要高。
4、一个例子
代码链接 http://js.jirengu.com/boyocekayo/1/edit html结构
|
|
css样式
|
|
正常情况下,绿色的a1的z-index
比蓝色的b1高,所以a1能盖住b1
出现了层叠上下文后,即使a1的z-index:9999;
,b1z-index:0;
,蓝色的b1还是还是盖住了绿色的a1。
- 原文作者:Enoch Qin
- 原文链接:https://dreamqyq.github.io/post/CSS/css-stacked-context/
- 版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 4.0 国际许可协议进行许可,非商业转载请注明出处(作者,原文链接),商业转载请联系作者获得授权。