我想使用简单的javascript和CSS而不使用库或插件来创建卡片翻转效果(与webkit转换和3D变换相同),并使其跨浏览器兼容。由于大多数CSS3属性适用于webkit浏览器,而且大多数javascript解决方案都使用了像jquery和其插件这样的库。请问我该如何实现呢?
任何帮助将不胜感激。
谢谢, manishekhawat
任何帮助将不胜感激。
谢谢, manishekhawat
<div class="flip-container" ontouchstart="this.classList.toggle('hover');">
<div class="flipper">
<div class="front">
<!-- front content -->
</div>
<div class="back">
<!-- back content -->
</div>
</div>
</div>
有两个内容窗格,"front" 和 "back",正如您所期望的那样,但还有两个包含元素,其CSS解释了它们的特定角色。 还要注意ontouchstart部分,它允许在触摸屏上交换窗格。
CSS
/* entire container, keeps perspective */
.flip-container {
perspective: 1000;
}
/* flip the pane when hovered */
.flip-container:hover .flipper, .flip-container.hover .flipper {
transform: rotateY(180deg);
}
.flip-container, .front, .back {
width: 320px;
height: 480px;
}
/* flip speed goes here */
.flipper {
transition: 0.6s;
transform-style: preserve-3d;
position: relative;
}
/* hide back of pane during swap */
.front, .back {
backface-visibility: hidden;
position: absolute;
top: 0;
left: 0;
}
/* front pane, placed above back */
.front {
z-index: 2;
/* for firefox 31 */
transform: rotateY(0deg);
}
/* back, initially hidden pane */
.back {
transform: rotateY(180deg);
}
.flip-container:hover .flipper, .flip-container.hover .flipper, .flip-container.flip .flipper
{
transform: rotateY(180deg);
}
将flip类添加到容器元素中,即可使用JavaScript翻转卡片--无需用户悬停。像这样的JavaScript注释:
document.querySelector("#myCard").classList.toggle("flip")
就可以完成翻转!
CSS垂直翻转
执行垂直翻转与翻转轴和添加transform-origin坐标值一样简单。必须更新翻转的原点并将卡片旋转另一个方向:
.vertical.flip-container {
position: relative;
}
.vertical .back {
transform: rotateX(180deg);
}
.vertical.flip-container .flipper {
transform-origin: 100% 213.5px; /* half of height */
}
.vertical.flip-container:hover .flipper {
transform: rotateX(-180deg);
}