html - translateZ 不适用于 Firefox

标签 html css firefox css-transforms

我一直在尝试使用 translateZ 将子元素“list”隐藏在父元素“div2”的后面。它在 chrome 中运行得非常好,但在 firefox 上却不行。请一些人帮忙。

链接到 JSFiddle。 translateZ on firefox

.list {
  width: 200px;
  height: 10px;
  background-color: yellow;
  -moz-transform: translateZ(-1em);
  -webkit-transform: translateZ(-1em);
}

请在此处找到图片 Image Link

左侧的图像在 chrome 上可以正常工作。黄色条在红色 div 后面。右边的图片来自 firefox,其中黄色条位于红色 div 的前面 - 这出乎意料。

最佳答案

The transform-style: preserve-3d; isn't inherited ,它必须设置为层次结构中的每个后代,以将它们保持在相同的 3D 空间中。

您在 #div1#div2 中保留了 3D 继承,但在 .sub 孙子,因此您希望 Z 移动的 .list 孙子的血统被打破。

如果您将它添加到您的 .sub CSS,它将接受其子级 .list 到 3D 空间并应用 Z 变换。

.sub {
  height: 20px;
  width: 50px;
  background-color: black;
  transform-style: preserve-3d;
}

关于html - translateZ 不适用于 Firefox,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46625224/

相关文章:

jquery - 没有滚动链接定位的当前导航位置

html - html 旁边不需要的白色区域

html - Bootstrap 输入标签溢出面板主体

Html 5 选择列表选项在 chrome 悬停时更改背景颜色

html - IE 8 不会显示宽度 100%

database - 我应该在 Firefox 扩展中使用哪个轻量级数据库?

CSS3 : opacity vs filter opacity?

javascript - 如何使具有绝对位置属性的jquery UI拖放元素响应?

php - CSS bootstrap 计算列数

javascript - Firefox 上的 event.target