设置实际宽度/高度/位置的动画效果往往不是很好,尤其是在像您现在这样同时执行多个动画时。移动/调整元素大小
transform
表现更好。
在这种情况下,我建议您设置心脏的初始大小,然后使用
scale
转换以产生脉冲效应。使用这种方法,您还可以从三个动画转换为一个动画,这对浏览器来说更容易处理,而且您不必担心将它们全部同步。
为了使文本不随心脏收缩,可以在其周围放置一个包装器,并将文本绝对放置在包装器的中心、心脏的顶部。然后改变心脏本身,而不是包装。(或者,如果希望文本与心脏一起收缩,请保持与现在相同的HTML结构。)
html,
body,
.container {
height: 100%;
}
.container {
display: flex;
justify-content: center;
align-items: center;
}
.heart-wrapper {
position: relative;
width: 80px;
height: 80px;
}
.heart {
display: flex;
justify-content: center;
align-items: center;
width: 100%;
height: 100%;
background-color: red;
transform: rotate(-45deg) scale(1);
transform-style: preserve-3d;
animation: pulse 1s;
animation-iteration-count: infinite;
animation-direction: alternate;
}
.heart::before {
left: 40px;
}
.heart::after {
top: -40px;
}
.heart::after,
.heart::before {
background-color: red;
content: "";
width: 80px;
height: 80px;
border-radius: 50%;
position: absolute;
transform: translateZ(-1px);
}
@keyframes pulse {
from {
transform: rotate(-45deg) scale(1);
}
to {
transform: rotate(-45deg) scale(0.6);
}
}
.text {
position: absolute;
top: 40%; /* slightly off-center to the top, so it appears centered when the heart shrinks */
left: 50%;
transform: translate(-50%, -50%);
text-align: center;
color: white;
font-family: "Comic Sans MS";
font-size: 100%;
margin: 0;
}
<div class="container">
<div class="heart-wrapper">
<div class="heart"></div>
<div class="text">some text</div>
</div>
</div>