Как сделать - 3D Flip Box
Узнайте, как создать флип-бокс с помощью CSS.
Флип-бокс
Наведите указатель мыши на поля ниже, чтобы увидеть эффект:
Горизонтальный флип:
Лицевая сторона
Задняя сторона
Вертикальное отражение:
Лицевая сторона
Задняя сторона
Как создать флип-бокс
Шаг 1) Добавьте HTML:
Пример
<div class="flip-box">
<div class="flip-box-inner">
<div class="flip-box-front">
<h2>Front
Side</h2>
</div>
<div
class="flip-box-back">
<h2>Back Side</h2>
</div>
</div>
</div>
Шаг 2) Добавьте CSS:
Пример
/* The flip box container - set the width and height to whatever you want. We
have added the border property to demonstrate that the flip itself goes out of
the box on hover (remove perspective if you don't want the 3D effect */
.flip-box {
background-color: transparent;
width: 300px;
height: 200px;
border: 1px solid #f1f1f1;
perspective:
1000px; /* Remove this if you don't want the 3D effect */
}
/* This
container is needed to position the front and back side */
.flip-box-inner {
position: relative;
width: 100%;
height: 100%;
text-align: center;
transition: transform
0.8s;
transform-style: preserve-3d;
}
/* Do an horizontal
flip when you move the mouse over the flip box container */
.flip-box:hover .flip-box-inner {
transform: rotateY(180deg);
}
/* Position the front and back side */
.flip-box-front, .flip-box-back {
position: absolute;
width: 100%;
height: 100%;
-webkit-backface-visibility: hidden; /* Safari */
backface-visibility: hidden;
}
/* Style the front side */
.flip-box-front {
background-color: #bbb;
color: black;
}
/* Style the back side */
.flip-box-back {
background-color: dodgerblue;
color: white;
transform: rotateY(180deg);
}
Вертикальный флип
Чтобы сделать вертикальное отражение вместо горизонтального, используйте rotateX
метод вместо rotateY
:
Пример
.flip-box:hover .flip-box-inner {
transform: rotateX(180deg);
}
.flip-box-back {
transform: rotateX(180deg);
}
Примечание. Эти примеры не работают должным образом на планшетах и/или мобильных телефонах.
Совет. Перейдите к нашему учебному пособию по двухмерным преобразованиям CSS , чтобы узнать больше о двухмерных преобразованиях, таких как метод rotate().
Совет: перейдите к нашему учебному пособию по 3D-преобразованиям CSS , чтобы узнать больше о 3D-преобразованиях.