CSS中的绘制顺序,chrome和firefox在使用3d转换时的不同点
一般规则
浏览器如何确定绘画内容的顺序?猜测可能是浏览器将按照DOM中指定的顺序来绘制内容,就是它在页面的源代码中出现的顺序。
我们可以构造一个简单的示例,显示两个div。我们通过给两个div之一赋予负的margin-top来使他们重叠。
<style>
.box {
width: 8ex;
height: 8ex;
padding: 0.2ex;
color: white;
font-weight: bold;
text-align: right;
}
.blue { background: #99DDFF; }
/* The second div has a negative top margin so that it overlaps
with the first (blue) div. Also, shift it over to the right
slightly. */
.green {
background: #44BB99;
margin-left: 3ex;
margin-top: -6ex;
}
</style>
<div class="blue box">1</div>
<div class="green box">2</div>
效果如下图:
data:image/s3,"s3://crabby-images/e16fc/e16fca0f0b5828e1bef39d1e6383771ef1308a3f" alt=""
使用该 z-index属性,我们可以覆盖浏览器使用的常规绘制顺序。我们给绿色div一个 z-index并使其相对定位。再在绿色div里面添加一个黄色子div,以了解它如何影响子项。
<div class="blue box">0</div>
<div class="green box" style="position: relative; z-index: -1;">-1
<div class="yellow box" style="position: relative; z-index: 1000;">1000</div>
</div>
效果如下图:
data:image/s3,"s3://crabby-images/9a603/9a603443c898d4d55d9d0c22cf8fd18c84e661ce" alt=""
如果给黄色div一个比较大的z-index会发生什么呢?
<div class="blue box">0</div>
<div class="green box" style="position: relative; z-index: -1;">-1
<div class="yellow box" style="position: relative; z-index: 1000;">1000</div>
</div>
效果如下图:
data:image/s3,"s3://crabby-images/d2571/d25714a40f1f44ad3ce384798bd9bec00dc4ed19" alt=""
黄色div没有显示在“最高”层,这是因为绿色div使用了z-index创建了一个stacking context,堆栈上下文中的内容作为一个单元绘制在一起,并且堆栈内容之外的项目将永远不会在它们之间绘制(一般是这样,下面会有一个方法打破这种规则)。
打破规则,chrome和firefox的不同
CSS中充满了奇技淫巧,一个层叠上下文中有没有办法被“插入”别的元素呢? 有!
<style>
.salmon {
background: salmon;
margin-top: -5ex;
margin-left: 4ex;
}
</style>
<div class="blue box">0</div>
<div style="position: relative; z-index: -2;">
<div class="green box">-2</div>
<div class="salmon box">-2</div>
</div>
效果如下图:
data:image/s3,"s3://crabby-images/ea92a/ea92a5a9f8bc3a4341299ae344fb74f8ed74f6dd" alt=""
现在,我们对该示例进行两个修改。首先,我们将示例包装在带有
transform-style:preserve-3d的div中,这会将所有子级放置在3d空间中。最后,我们使用3d转换将带有-2 的div之一“推出”屏幕。
<div style="transform-style: preserve-3d;">
<div class="blue box">0</div>
<div style="position: relative; z-index: -2;">
<div class="green box">-2</div>
<div class="salmon box" style="transform: translateZ(50px);">-2</div>
</div>
</div>
在chrome浏览器上,效果如下图:
data:image/s3,"s3://crabby-images/09606/096069d0a1814d8073ed7b4f8b2f92a656d99d02" alt=""
可以看到,蓝色div被插在了绿色div和红色div之间,别忘了绿色div和红色(salmon)div是一个层叠上下文哦!
但是,在firefoxl浏览器上没有效果,蓝色div不会被插入到绿色和红色之间。
data:image/s3,"s3://crabby-images/51de8/51de863c9aea0e8e51933a0a06a27642172bb2f0" alt=""
相关推荐
-
PHP8种变量类型的详细讲解2025-02-22 00:32:24
-
php+apache 和 php+nginx的区别2025-02-22 00:21:27
-
PHP:与workerman结合实现定时任务2025-02-22 00:15:57
-
Nginx的Rewrite规则与实例2025-02-22 00:15:39
-
MySql中身份证字段的简单脱敏介绍2025-02-22 00:15:36