一个CSS3 动画执行完成后的问题...
问题描述
例:
在执行完一段css3动画后需要隐藏这个元素如何操作?也就是让它不重复动作.
使用animation参数forwards无效.
注:前提是不使用jQuery情况下能做到么?
问题解答
回答1:这个隐藏的话可以设置opacity:0
我们可以让一个元素的默认opacity=0
把动画放到一个一个类上,然后给把这个类付给这个属性
@keyframes ani{ 0%{opacity: 1}//此处显示转换为1 动画结束后就会自动隐藏了,因为元素的opacity为0,应该使用 display也可以,但我没用过,因为display没有动画效果}回答2:
不用jQUery,JavaScript可以接受么?
取决不同的类型,动画播放过程会触发两类事件:1. AnimationEvent2. TransitionEvent
动画结束的事件的两个实现分别是:1. animationend2. transitionend
Demo页面在这里,只测试过Chrome:http://codepen.io/longtian/pen/jEyrzN
兼容性大坑可以看AngularUI的这部分源码https://github.com/angular-ui/bootstrap/blob/7512b93fecb6f27df4f5aeba4c756c0c36aebbf2/src/transition/transition.js#L59
回答3:可以使用js的定时器。把定时器时间设置成和css动画时间一样就行了
回答4:http://jsfiddle.net/fevwehk3/
相关文章:
1. docker-compose中volumes的问题2. vim - docker中新的ubuntu12.04镜像,运行vi提示,找不到命名.3. python 多进程 或者 多线程下如何高效的同步数据?4. docker 下面创建的IMAGE 他们的 ID 一样?这个是怎么回事????5. docker-compose 为何找不到配置文件?6. php - 想要远程推送emjio ios端怎么搞 需要怎么配合7. java - Hibernate查询的数据是存放在session中吗?8. 一个走错路的23岁傻小子的提问9. angular.js - node.js中下载的angulae无法引入10. android - 添加multidex后在部分机型上产生anr的问题,该如何解决
