【发布时间】:2014-03-05 15:14:59
【问题描述】:
卡片翻转在所有浏览器中都可以正常工作,但在 IE10 中效果不佳,悬停后背面的内容旋转了 180 度。
我在谷歌上搜索了很多,但我没有找到任何针对 IE10 的修复程序,这是我的代码
HTML
<div class="flip-container">
<div class="flipper">
<div class="front">
<h2>Front content</h2>
</div>
<div class="back">
<h2>Back content</h2>
</div>
</div>
</div>
CSS
.flip-container {
perspective: 1000;
-webkit-perspective: 1000;
-moz-perspective: 1000;
-o-perspective: 1000;
}
.flip-container:hover .flipper, .flip-container.hover .flipper {
transform: rotateY(180deg);
-webkit-transform: rotateY(180deg);
-moz-transform: rotateY(180deg);
-ms-transform: rotateY(180deg);
-o-transform: rotateY(180deg);
}
.flip-container, .front, .back {
width: 200px;
height: 200px;
border-radius:50%;
}
.flipper {
transition: 0.6s;
-webkit-transition: 0.6s;
-moz-transition: 0.6s;
-ms-transition: 0.6s;
-o-transition: 0.6s;
transform-style: preserve-3d;
-webkit-transform-style: preserve-3d;
-moz-transform-style: preserve-3d;
-o-transform-style: preserve-3d;
-ms-transform-style: preserve-3d;
position: relative;
}
.flipper h2{
margin: 80px 0 0 30px;
}
.front, .back {
backface-visibility: hidden;
-webkit-backface-visibility: hidden;
-moz-backface-visibility: hidden;
-o-backface-visibility: hidden;
background:#f2f2f2;
border:1px solid #ccc;
position: absolute;
top: 0;
left: 0;
}
/* front pane, placed above back */
.front {
z-index: 2;
}
.back {
transform: rotateY(180deg);
-webkit-transform: rotateY(180deg);
-moz-transform: rotateY(180deg);
-ms-transform: rotateY(180deg);
-o-transform: rotateY(180deg);
}
【问题讨论】:
-
您在 CSS 中使用
transform-style: preserve-3d。 IE 还不支持该属性。 caniuse.com/#search=3d%20transfor -
另外,我建议在使用像
-webkit-这样的供应商前缀时,将不带前缀的标准属性放在供应商前缀之后,以便在支持时最后获取它。 -
我在供应商前缀之后添加了标准属性,但我没有得到解决方案
-
Keith 为
transform-style属性编写的preserve-3d值尚不受IE 支持。另请参阅description at Microsoft。 -
已经发布了一个解决方案。为什么不考虑投票赞成/反对?