gpt4 book ai didi

html - CSS 动画 rotate3d 在 Safari 中不起作用

转载 作者:太空宇宙 更新时间:2023-11-04 01:04:10 25 4
gpt4 key购买 nike

无论我如何尝试,我都无法让此动画在 Safari 12 中运行。我已经尝试了供应商前缀和所有的方法,但没有任何效果。

它在 Chrome 中运行良好。有人有什么想法吗?

<div class="spinners"></div>

这是CSS:

@keyframes spinx {
0% {
transform: rotate3d(0, 1, 1, 360deg);
}
100% {
transform: rotate3d(0, 0, 0, 360deg);
}
}
.spinners {
display: block;
width: 100%;
height: 4rem;
overflow: hidden;
position: relative;
}
.spinners:before, .spinners:after {
content: "";
width: 4rem;
height: 4rem;
border: 3px solid red;
border-radius: 50%;
position: absolute;
top: 50%;
left: 50%;
margin: -2rem 0 0 -2rem;
display: block;
transform-origin: 50% 50% 0;
}
.spinners:before {
animation: spinx 2s infinite linear;
}
.spinners:after {
border-color: blue;
animation: spinx 4s infinite linear alternate;
}

这是一个演示: https://codepen.io/Skinner927/pen/vVEdag

最佳答案

似乎 Safari 和 Firefox 都无法识别两个关键帧之间的变化。要解决这个问题,您可以使用中间关键帧:

50% {
transform: rotate3d(0, 1, 1, 180deg);
}

演示:

@keyframes spinx {
0% {
transform: rotate3d(0, 1, 1, 360deg);
}
50% {
transform: rotate3d(0, 1, 1, 180deg);
}
100% {
transform: rotate3d(0, 0, 0, 0);
}
}

.spinners {
display: block;
width: 100%;
height: 4rem;
overflow: hidden;
position: relative;
}

.spinners:before,
.spinners:after {
content: "";
width: 4rem;
height: 4rem;
border: 3px solid red;
border-radius: 50%;
position: absolute;
top: 50%;
left: 50%;
margin: -2rem 0 0 -2rem;
display: block;
transform-origin: 50% 50% 0;
}

.spinners:before {
animation: spinx 2s infinite linear;
}

.spinners:after {
border-color: blue;
animation: spinx 4s infinite linear alternate;
}
<div class="box">
<div class="spinners"></div>
</div>

关于html - CSS 动画 rotate3d 在 Safari 中不起作用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52571632/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com