Эта веб-страница предназначена для анимации блоков и отображения некоторых текстовых деталей, однако, когда поле переворачивается, я не могу сделать отступ для текста внутри поля.
Я хочу уменьшить размер текста для поля, которое переворачивается. Однако выравнивание не влияет на текст. Я хочу добавить весь текст внутри поля, и они не должны выходить за пределы поля.
https://codepen.io/srinabh/pen/XBKQdm
flexbox{
margin: 0;
padding: 0;
list-style-type: none;
display: flex;
flex-flow: row wrap;
justify-content: center;
}
.panels{
list-style-type: none;
padding: 0;
width: 100%;
margin: 2% auto;
}
.panels li{
position: relative;
width: 20%;
margin: 5px;
display: block;
box-sizing: border-box;
float: left
}
.panels li div{
width: 100%;
padding: 50% 0;
text-align: center;
line-height: 0;
cursor: pointer;
-moz-box-shadow: 0px 2px 7px rgba(0, 0, 0,0.2);
-webkit-box-shadow: 0px 2px 7px rgba(0, 0, 0, .2);
box-shadow: 0px 2px 7px rgba(0, 0, 0, .2);
}
.panels div.back{
background: linear-gradient(to bottom, #e40000, #f07611);
transform: rotateY(90deg);
font-family: Cabin;
font-size: 1.4707843137254901vw;
color: #3d4250;
position: absolute;
left: 0;
top:0;
}
.panel div.front{
background: white;
font-family: Cabin;
font-size: 1.9607843137254901vw;
color: #3d4250;
position: relative;
}
/*// ANIMATION STYLES //*/
.panels li:hover div.front{
animation: twirl 0.2s ease-in forwards;
}
.panels li:hover div.back{
animation: twirl 0.2s 0.2s ease-in forwards reverse;
}
@keyframes twirl{
0%{
transform: rotateY(0deg);
}
100%{
transform: rotateY(90deg);
}
}
<ul class = "panels flexbox">
<li>
<div class = "front">Sense of Purpose</div>
<div class = "back"><h6>Sense of purpose</h6>
"Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. </div>
</li>
<li>
<div class = "front" style = "background: #9126f4">Get to</div>
<div class = "back">The chopper</div>
</li>
<li>
<div class = "front" style = "background: #21bf3b">foo</div>
<div class = "back">bar</div>
</li>
<li>
<div class = "front" style = "background: #c3333d">tempus</div>
<div class = "back" >fugit</div>
</li>
<li>
<div class = "front" style = "background: #c3333d">html</div>
<div class = "back">rocks</div>
</li>
<li>
<div class = "front" style = "background: #21bf3b">A</div>
<div class = "back">B</div>
</li>
<li>
<div class = "front" style = "background: #9126f4">Super</div>
<div class = "back" >Mariokart</div>
</li>
<li>
<div class = "front" style = "background: #267df4">j</div>
<div class = "back">Query</div>
</li>
</ul>
🤔 А знаете ли вы, что...
HTML поддерживает механизмы для встраивания JavaScript-кода для создания интерактивных элементов.
Удаление высоты строки решит проблему перекрытия текста.
.panels li div{
width: 100%;
padding: 50% 0;
text-align: center;
/*line-height: 0;*/
cursor: pointer;
-moz-box-shadow: 0px 2px 7px rgba(0, 0, 0,0.2);
-webkit-box-shadow: 0px 2px 7px rgba(0, 0, 0, .2);
box-shadow: 0px 2px 7px rgba(0, 0, 0, .2);
}
И добавьте высоту в div.
.panels div.back{
background: linear-gradient(to bottom, #e40000, #f07611);
transform: rotateY(90deg);
height: 18px;
font-family: Cabin;
/* font-size: 1.4707843137254901vw;*/
color: #3d4250;
position: absolute;
left: 0;
top:0;
}
.panel div.front{
background: white;
font-family: Cabin;
/*font-size: 1.9607843137254901vw;*/
color: #3d4250;
position: relative;
}