【发布时间】:2017-07-20 14:41:56
【问题描述】:
随附的代码包含一个带有<p> 的动画 CSS 框。它正在工作,但问题是,为什么它没有垂直对齐?我将需要使用 flex 函数:“align-items = center”使其对齐。
.LoaderBox {
width: 100%;
border: 1px solid rgba(255, 0, 0, 1.00);
display: flex;
justify-content: center;
}
.LoaderBox>p {
color: rgba(106, 106, 106, 1.00);
font-size: 15px;
margin-left: 20px;
display: block;
}
.LoaderBox_spinner {
width: 20px;
height: 20px;
background-color: #333;
-webkit-animation: sk-rotateplane 1.2s infinite ease-in-out;
animation: sk-rotateplane 1.2s infinite ease-in-out;
display: block;
}
@-webkit-keyframes sk-rotateplane {
0% {
-webkit-transform: perspective(120px)
}
50% {
-webkit-transform: perspective(120px) rotateY(180deg)
}
100% {
-webkit-transform: perspective(120px) rotateY(180deg) rotateX(180deg)
}
}
@keyframes sk-rotateplane {
0% {
transform: perspective(120px) rotateX(0deg) rotateY(0deg);
-webkit-transform: perspective(120px) rotateX(0deg) rotateY(0deg)
}
50% {
transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg);
-webkit-transform: perspective(120px) rotateX(-180.1deg) rotateY(0deg)
}
100% {
transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
-webkit-transform: perspective(120px) rotateX(-180deg) rotateY(-179.9deg);
}
}
<div class="LoaderBox">
<div class="LoaderBox_spinner"></div>
<p>Verifying</p>
</div>
【问题讨论】:
-
align-items的默认值是stretch,这意味着元素将占据 flex 容器的整个高度。在这里,您手动设置了微调器的height,因此stretch被覆盖,它的行为似乎类似于flex-start。最好的解决方案是使用align-items: center来解决这个问题。 -
我还是不明白背后的原因。 “box”和“
”似乎都不是相同的对齐方式。看一下“
”,它应该在
的顶部,但是它的垂直对齐...那为什么会这样呢?这就是我不明白的原因。
标签: html css flexbox css-animations