您的位置:首页技术文章
文章详情页

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

【字号: 日期:2023-08-04 09:53:11浏览:30作者:猪猪

问题描述

例:

在执行完一段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/

标签: CSS
相关文章: