css3动画播放后如何停止在最后的状态

html-css012

css3动画播放后如何停止在最后的状态,第1张

新建keyframes元素,命名为myFirst。设置百分比,编写Animation属性对属性值的引用。为了开考虑兼容性问题,可以多写几个备选,详细步骤:

1、首先,准备好HTML前期工作以及对DIV的一个简单设置。

2、然后,新建keyframes元素,命名为myFirst。

3、然后,可以在设置百分比,不仅仅只能设置4个,大家可以根据需求设置。

4、这时候,可以为他写上各种百分比的颜色。

5、此时,就能编写Animation属性对属性值的引用。

6、为了开考虑兼容性问题,可以多写几个备选。

1、首先看看一个动画代码:(不是什么高大上的效果,只是简单的颜色变化)

@-webkit-keyframes indexframe { 0% {background-color:#000000color:#FFFFFF} 50% {background-color:#FFFFFFcolor:#000000} 100% {background-color:#000000color:#FFFFFF} } #index_href { -webkit-animation: indexframe 8s infinitedisplay:blockposition:relativetop:400pxleft:180pxwidth:200pxheight:80pxborder-radius:15pxtext-align:centerline-height:80pxfont-style:italicfont-size:24pxtext-decoration:nonecolor:#FFFFFFbackground-color:#000000opacity:0.5}

为了方便,也就写了兼容chrome的css3样式,其他的换个前缀就好,在这里就不过多的说了。

2、为这个a(id=“index_href”)添加一个伪类:

这是原本准备添加的:

#index_href:hover { background-color:#ffffffcolor:#000000opacity:0.5}

但是运行之后发现动画因为设置的是

infinite //无限循环的效果

所以当需要触发伪类的效果时,动画还是会依然进行,这时候就需要停止之前的无限循环的动画了。

用css3的思路就是重新设置一个伪类的动画,把前面的动画给覆盖了。这样的话,我们就可以把伪类要改变的东西设置为动画效果,然后直接覆盖上去就行了。代码如下:

#index_href:hover { -webkit-animation:indexend 0scolor:#000000opacity:0.5} @-webkit-keyframes indexend { 0% {background:#000000} 100% {background:#FFFFFF} }

这里重新定义一个动画,命名为indexend,然后添加到hover伪类中去,设置动画的过渡时间为0s,这样可以达到瞬间变道动画的结束样式,以达到hover样式的直接改变。

这样就成功的实现了之前动画的停止与后来样式的变化。