一个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. css3 - css字体样式加填充色而不是背景色2. css - 前端flex布局嵌套内层的布局不起作用?3. html按键开关如何提交我想需要的值到数据库4. html5 - HTML代码中的文字乱码是怎么回事?5. android - 求 360浏览器 百度浏览器 搜狗浏览器的最新启动类名6. javascript - 微信小程序 wx.downloadFile下载文件大小有限制吗7. css - ul ol前边的标记如何调整样式呢8. javascript - 如何通过参数获取Object的子节点?9. python3.5 urllib.parse.unquote 乱码10. css3动画 - 实现css3推倒动画