use*_*121 15 html css firefox transform css3
Firefox中的3D变换似乎与z-index存在问题.在我看来,渲染是"忽略"3D Z位置,并简单地使用来自DOM的z-index.有趣的是,当可见部分变小时,只有轮子的一部分可见,z-index突然正确,尽管其他人工制品开始出现.
这个交集错误演示自2011年以来在Firefox中被窃听,但是我的圈子没有交叉 - 所以我希望它在某种程度上是可能的. http://jsfiddle.net/yNfQX/21/
Firefox Bugtracker:https://bugzilla.mozilla.org/show_bug.cgi ? id = 689498
.perspective {
width: 400px;
height: 400px;
position: relative;
perspective: 3000px;
display: block;
}
.dcw {
width: 100%;
height: 100%;
position: absolute;
transform-style: preserve-3d;
}
.dc {
top: calc(50% - 44px);
left: calc(50% - 44px);
margin: auto;
border-radius: 50%;
position: absolute;
cursor: pointer;
transform-style: preserve-3d;
width: 88px;
height: 88px;
border: 1px solid black;
}Run Code Online (Sandbox Code Playgroud)
<div class="perspective">
<div class="dcw">
<div class="dc" style="background-color: rgba(255,0,0,1);transform: rotateZ( 0deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(251,4,4,1);transform: rotateZ( 10deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(248,7,7,1);transform: rotateZ( 20deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(244,11,11,1);transform: rotateZ( 30deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(241,14,14,1);transform: rotateZ( 40deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(237,18,18,1);transform: rotateZ( 50deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(234,21,21,1);transform: rotateZ( 60deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(230,25,25,1);transform: rotateZ( 70deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(227,28,28,1);transform: rotateZ( 80deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(223,32,32,1);transform: rotateZ( 90deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(219,36,36,1);transform: rotateZ( 100deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(216,39,39,1);transform: rotateZ( 110deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(212,43,43,1);transform: rotateZ( 120deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(209,46,46,1);transform: rotateZ( 130deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(205,50,50,1);transform: rotateZ( 140deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(202,53,53,1);transform: rotateZ( 150deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(198,57,57,1);transform: rotateZ( 160deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(195,60,60,1);transform: rotateZ( 170deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(191,64,64,1);transform: rotateZ( 180deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(187,68,68,1);transform: rotateZ( 190deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(184,71,71,1);transform: rotateZ( 200deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(180,75,75,1);transform: rotateZ( 210deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(177,78,78,1);transform: rotateZ( 220deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(173,82,82,1);transform: rotateZ( 230deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(170,85,85,1);transform: rotateZ( 240deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(166,89,89,1);transform: rotateZ( 250deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(163,92,92,1);transform: rotateZ( 260deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(159,96,96,1);transform: rotateZ( 270deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(155,100,100,1);transform: rotateZ( 280deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(152,103,103,1);transform: rotateZ( 290deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(148,107,107,1);transform: rotateZ( 300deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(145,110,110,1);transform: rotateZ( 310deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(141,114,114,1);transform: rotateZ( 320deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(138,117,117,1);transform: rotateZ( 330deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(134,121,121,1);transform: rotateZ( 340deg ) translateX(125px) rotateX( -60deg ); "></div>
<div class="dc" style="background-color: rgba(131,124,124,1);transform: rotateZ( 350deg ) translateX(125px) rotateX( -60deg ); "></div>
</div>
</div>Run Code Online (Sandbox Code Playgroud)
JSFiddle:https://jsfiddle.net/gvquf0g6/
z-index问题(来自Firefox的截图):
工件问题,以及带有部分可见轮的工作z-index(来自Firefox的截图):

将鼠标移动到工件(缺失的块)上会将它们填充到第一次渲染时应该是这样.