当您将鼠标悬停在Chrome中的元素上时,时钟的底部开始向下移动。如果您尝试在Firefox中执行此操作,它将从错误的位置开始。悬停时SVG动画从Firefox中的错误位置开始
HTML
<g id="clock_bottom_3" opacity="0.316786674" transform="translate(72.000000, 306.000000)">
<ellipse id="Oval" fill="url(#radialGradient-1)" opacity="0.24" transform="translate(87.000000, 52.000000) rotate(-180.000000) translate(-87.000000, -52.000000) " cx="87" cy="52" rx="87" ry="52"></ellipse>
<ellipse id="Oval" fill="url(#radialGradient-2)" opacity="0.24" transform="translate(117.000000, 52.000000) scale(-1, 1) rotate(-180.000000) translate(-117.000000, -52.000000) " cx="117" cy="52" rx="87" ry="52"></ellipse>
</g>
CSS:
#clock_bottom_3 {transition: transform 0.3s;}
svg:hover #clock_bottom_3 {transform: translate(72px, 320px);}
https://jsfiddle.net/kd7x068g/
不知道FF有多少是在这里,也没有事情会如何与即将到来的SVG2标准改变,但事实上,这似乎FF不允许CSS从转变'transform'属性为其等效的CSS。一个简单的解决方法是在任何地方使用css:https://jsfiddle.net/kd7x068g/1/ – Kaiido
不,但它仍然应用非CSS转换。 –