8

我试图让一个标题飞入,然后当你悬停它时,它应该会摇晃(都带有 css3 动画)。它以我想要的方式飞行,也会震动,但是在我将鼠标从元素中移除后,即使我设置了 `-animation-fill-mode: forwards ; 当我查看 chromedevtools 时,该元素永远不会改变它的边距(即使动画有效..)。我可以解决这个问题吗?

另外,有没有办法防止第一个动画在摇动动画之后再次发生?

飞行动画:

#name {
margin:40px 2% 40px 0;

-webkit-animation:flyin 1.5s;
-webkit-animation-fill-mode: forwards;
-webkit-animation-timing-function: ease-in-out;
-webkit-animation-delay: 1800ms;
}

@-webkit-keyframes flyin {

from{margin-right: 2%;}
30% {margin-right: 12%;}
50% {margin-right: 9%;}
60% {margin-right: 10%;}
to {margin-right: 10%;}
}

摇动动画:

#name:hover {
        **margin-right: 10%; //i also have to set this?! or it starts at 2%**
        -webkit-animation:shake 0.7s;
        -webkit-animation-fill-mode: forwards;
        -webkit-transform-origin:50% 50%; 
        -webkit-animation-iteration-count: infinite; 
        -webkit-animation-timing-function: linear;


    }

    @-webkit-keyframes shake { 
0% { -webkit-transform: translate(2px, 1px) rotate(0deg); } 
10% { -webkit-transform: translate(-1px, -2px) rotate(-1deg); } 
20% { -webkit-transform: translate(-3px, 0px) rotate(1deg); } 
30% { -webkit-transform: translate(0px, 2px) rotate(0deg); } 
40% { -webkit-transform: translate(1px, -1px) rotate(1deg); } 
50% { -webkit-transform: translate(-1px, 2px) rotate(-1deg); } 
60% { -webkit-transform: translate(-3px, 1px) rotate(0deg); } 
70% { -webkit-transform: translate(2px, 1px) rotate(-1deg); } 
80% { -webkit-transform: translate(-1px, -1px) rotate(1deg); } 
90% { -webkit-transform: translate(2px, 2px) rotate(0deg); } 
100% { -webkit-transform: translate(2px, 1px) rotate(0deg); } 
}
4

2 回答 2

10

设置animation-fill-mode: forwards意味着动画完成执行后,动画将保持最终属性,直到被移除。当鼠标停止悬停时,该-webkit-animation属性返回到它的默认值(空白),这意味着shake动画被移除,一切都恢复到原来的样子。要使动画保持其最终属性,您必须将shake动画应用于元素。(换句话说,animation-fill-mode只有在应用动画时才有效。)

于 2012-11-26T22:05:44.307 回答
1

要让动画在鼠标离开元素时保持在其状态,您需要将所有动画属性添加到处于正常状态的元素,而不是 :hover,加上:

animation-play-state: paused

:hover添加时:

animation-play-state: running

于 2019-11-19T16:59:24.833 回答