javascript – 循环CSS动画

前端之家收集整理的这篇文章主要介绍了javascript – 循环CSS动画前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

所以我在这里有这个漂亮的CSS动画,我希望它循环.

我几乎没有CSS动画的经验,但遗憾的是没有想法如何做到这一点.
如果有人在这里帮助我,我真的很感激.
谢谢!

HTML

使用Javascript

$("#msg").click(function() {
    var duration = 1400;
    $msg = $(this);
    $msg.css("-webkit-transform","scale(2)")
        .css("-webkit-transition-timing-function","ease-out")
        .css("-webkit-transition-duration",duration + "ms");
    setTimeout(function () {
        $msg.css("-webkit-transform","scale(1)")
            .css("-webkit-transition-timing-function","ease-in")
            .css("-webkit-transition-duration",duration + "ms");
    },duration);
});

CSS

#msg { font-size: 40pt; font-weight:bold; text-align:center; line-height: 120pt; }
最佳答案
Praveen的解决方案应该更接近您的要求,但我将提供解决方using CSS3 animations,而不是使用jQuery来设置转换动画. IMO更容易维护和理解:

CSS

@-webkit-keyframes foo {
  from {
    -webkit-transform:scale(1);
  }
  to {
    -webkit-transform:scale(2);
  }
}

然后JS:

$("#msg").click(function() {
    var duration = 1400;
    $msg = $(this);
    //Syntax is: animation-name animation-duration[ animation-timing-function][ animation-delay][ animation-iteration-count][ animation-direction]
    $msg.css("animation","foo " + duration + "ms ease infinite alternate");
});

Fiddle

我没有在上面使用可选的animation-delay参数,其余的应该非常简单.具有交替方向的无限迭代计数将无限期地执行动画,将动画方向从(从到)转换为(从到),直到您调用$msg.css(“animation”,“”)来移除动画.

PS. jQuery 1.8将自动为你做JS中的前缀.
当然,你仍然必须在CSS前面加上非webkit浏览器的工作. Prefixr应该这样做.

Fiddle带有前缀CSS.

猜你在找的jQuery相关文章