css层叠规则

# 从零开始的前端生活 --css层叠规则

层叠上下文

网页上的元素其实是三维的,类似于高中学的左手坐标系,Z轴就是垂直于屏幕。层叠上下文跟“块状格式化上下文”(BFC)类似,只要元素拥有某些特定的css属性,就会表现出层叠上下文的特点。

层叠顺序

更完整的7阶层叠顺序图

前提是重叠在一起,就会按照上图的规则呈现。

层叠准则

(1) 谁大谁上:如生效的z-index属性值,大的就覆盖小的。

(2)后来居上:当元素的层叠顺序一致的时候,比较后面的元素就会覆盖前面的元素。

层叠上下文创建

普通元素可以添加overflow:hidden;使他成为BFC元素。而层叠上下文也可以添加某些css属性变成的。

  1. 根层叠上下文指的是页面根元素。
  2. 对于position为relative/absolute/fixed的元素,当他的z-index不是auto时,就会创建层叠上下文。
  3. css3新属性
    • 元素为flex布局元素,同时z-index值不是auto。
    • 元素的opacity不是1
    • 元素的transform值不是none
    • 元素的filter不是none
    • 元素的mix-blend-mode不止normal
    • 元素的isolation不是isolate
    • 元素的will-change属性值为上面2~6的任意一个
    • 元素的-webkit-overflow-scrolling设为touch

楼上图片很重要,很多细节。

例子

<div class="box">
    1235543
    <img src="../image/pic02.jpg" alt="" class="img">
</div>
.box {
    width: 300px;
    height: 300px;
    background-color: pink;
    transform: scale(1);
}

.img {
    position: relative;
    z-index: -1;
    top: -10px;
}

很明显图片叠在背景上面,看楼上的图,z-index的负值优先于层叠上下文的background/border,里面的数字是匿名内联盒子,由上表可知,内联盒子优先级高于z-index负值。

所以效果如下

z-index

结语

看css世界,隐隐约约,懵懵懂懂,恍恍惚惚。

posted @ 2020-06-19 17:02  从零开始的代码生活  阅读(352)  评论(0编辑  收藏  举报