React CSS动画延迟属性不起作用

3htmauhk  于 2022-11-27  发布在  React
关注(0)|答案(1)|浏览(167)

关于React.js中动画元素的一个快速问题-我注意到,当尝试使用CSS中的animation-delay属性时,React似乎出于某种原因根本不应用这一规则。
例如,我尝试制作一个基本的加载组件,它只有一系列按顺序移动的基本圆圈,其CSS如下所示:

.--loaderContainer {
    position: relative;
    left: 50%;
    top: 50%;
    transform: translateX(-50%), translateY(-50%);
    width: 4rem;
    height: 4rem;
}

.--loaderContainer:nth-child(n) {
    width: 1rem;
    height: 1rem;
    border-radius: 9999px;
    margin: 0;
    padding: 0;
    position: absolute;
    animation-name: spin;
    animation-duration: 2s;
    animation-timing-function: ease;
    animation-iteration-count: infinite;
    animation-fill-mode: both;
}

.--loaderContainer:first-child {
    background-color: red;
    transform: rotate(270deg);
    animation-delay: -1.5s;
}

.--loaderContainer:nth-child(2) {
    background-color: blue;
    transform: rotate(180deg);
    animation-delay: -1s;
}

.--loaderContainer:nth-child(3) {
    background-color: green;
    transform: rotate(90deg);
    animation-delay: -0.5s;
}

.--loaderContainer:nth-child(4) {
    background-color: yellow;
}

@keyframes spin {
    0%,
    100% {
        transform: translate(0);
    }
    25% {
        transform: translate(160%);
    }
    50% {
        transform: translate(160%, 160%);
    }
    75% {
        transform: translate(0, 160%);
    }
}

就我所知,这应该是按顺序错开每个子元素,在不同的时间执行相同的动画。然而,出于某种原因,React只是播放动画,没有任何延迟,并在完全相同的时间让所有四个元素都有动画。
这似乎是一个非常基本的问题,虽然我已经寻找了各种答案,我只是似乎不能找到任何具体的解决方案,所以将是超级感谢任何帮助。谢谢!

5f0d552i

5f0d552i1#

如果四个圆圈都能看到,我想这个动画应该能正常工作。
animation-delay值可确保四个圆从动画的不同点开始,而不是实际延迟。
More about animation-delay
如果没有它,它们将从同一点开始并一起移动,同时彼此堆叠,导致只能看到一个圆(最后一个yellow圆,因为它在堆叠的顶部)。
下面是一个基本的例子,通过在所有圆圈中打开和关闭animation-delay来测试它的效果,它可以通过下面的“运行代码片段”按钮来运行。
希望能有所帮助。
第一个

相关问题