recherche

Maison  >  Questions et réponses  >  le corps du texte

一个CSS3 动画执行完成后的问题...

例:

在执行完一段css3动画后需要隐藏这个元素如何操作?也就是让它不重复动作.

使用animation参数forwards无效.

注:前提是不使用jQuery情况下能做到么?

迷茫迷茫2787 Il y a quelques jours515

répondre à tous(4)je répondrai

  • 巴扎黑

    巴扎黑2017-04-17 11:10:17

    这个隐藏的话可以设置opacity:0

    我们可以让一个元素的默认opacity=0

    把动画放到一个一个类上,然后给把这个类付给这个属性

    @keyframes ani{
        0%{opacity: 1}//此处显示转换为1 动画结束后就会自动隐藏了,因为元素的opacity为0,应该使用 display也可以,但我没用过,因为display没有动画效果
    }
    

    répondre
    0
  • 高洛峰

    高洛峰2017-04-17 11:10:17

    不用jQUery,JavaScript可以接受么?

    取决不同的类型,动画播放过程会触发两类事件:
    1. AnimationEvent
    2. TransitionEvent

    动画结束的事件的两个实现分别是:
    1. animationend
    2. transitionend

    Demo页面在这里,只测试过Chrome:
    http://codepen.io/longtian/pen/jEyrzN

    兼容性大坑可以看AngularUI的这部分源码
    https://github.com/angular-ui/bootstrap/blob/7512b93fecb6f27df4f5aeba4c756c0c36aebbf2/src/transition/transition.js#L59

    répondre
    0
  • 怪我咯

    怪我咯2017-04-17 11:10:17

    可以使用js的定时器。把定时器时间设置成和css动画时间一样就行了

    répondre
    0
  • 高洛峰

    高洛峰2017-04-17 11:10:17

    http://jsfiddle.net/fevwehk3/

    répondre
    0
  • Annulerrépondre