CSS3

  w3cschool      22:47     8

CSS3 animation 属性

   实例

使用简写属性,将动画与 div 元素绑定:

div { animation:mymove 5s infinite; -webkit-animation:mymove 5s infinite; /* Safari 和 Chrome */ }


   定义和用法

animation 属性是一个简写属性,用于设置六个动画属性:

  • animation-name

  • animation-duration

  • animation-timing-function

  • animation-delay

  • animation-iteration-count

  • animation-direction

注释:请始终规定 animation-duration 属性,否则时长为 0,就不会播放动画了。


默认值:none 0 ease 0 1 normal
继承性:no
版本:CSS3
JavaScript 语法:object.style.animation="mymove 5s infinite"

   语法

animation: name duration timing-function delay iteration-count direction;
描述
animation-name规定需要绑定到选择器的 keyframe 名称。。
animation-duration规定完成动画所花费的时间,以秒或毫秒计。
animation-timing-function规定动画的速度曲线。
animation-delay规定在动画开始之前的延迟。
animation-iteration-count规定动画应该播放的次数。
animation-direction规定是否应该轮流反向播放动画。


CSS3 animation-name 属性

   定义和用法

animation-name 属性为 @keyframes 动画规定名称。

注释:请始终规定 animation-duration 属性,否则时长为 0,就不会播放动画了。

默认值:none
继承性:no
版本:CSS3
JavaScript 语法:object.style.animationName="mymove"

   语法

animation-name: keyframename|none;
描述
keyframename规定需要绑定到选择器的 keyframe 的名称。
none规定无动画效果(可用于覆盖来自级联的动画)。


CSS3 animation-duration 属性

   实例

为 @keyframes 动画规定一个名称:

div { animation-duration:2s; -webkit-animation-duration:2s; /* Safari 和 Chrome */}


   定义和用法

animation-duration 属性定义动画完成一个周期所需要的时间,以秒或毫秒计。

默认值:0
继承性:no
版本:CSS3
JavaScript 语法:object.style.animationDuration="3s"

   语法

animation-duration: time;
描述
time规定完成动画所花费的时间。默认值是 0,意味着没有动画效果。


CSS3 animation-timing-function 属性


   实例

从开头到结尾以相同的速度来播放动画:

div { animation-timing-function:2s; -webkit-animation-timing-function:2s; /* Safari 和 Chrome */ }


   定义和用法

animation-timing-function 规定动画的速度曲线。

速度曲线定义动画从一套 CSS 样式变为另一套所用的时间。

速度曲线用于使变化更为平滑。

默认值:ease
继承性:no
版本:CSS3
JavaScript 语法:object.style.animationTimingFunction="linear"

   语法

animation-timing-function: value;

animation-timing-function 使用名为三次贝塞尔(Cubic Bezier)函数的数学函数,来生成速度曲线。您能够在该函数中使用自己的值,也可以预定义的值:

描述测试
linear动画从头到尾的速度是相同的。测试
ease默认。动画以低速开始,然后加快,在结束前变慢。测试
ease-in动画以低速开始。测试
ease-out动画以低速结束。测试
ease-in-out动画以低速开始和结束。测试
cubic-bezier(n,n,n,n)在 cubic-bezier 函数中自己的值。可能的值是从 0 到 1 的数值。

提示:请试着在下面的“亲自试一试”功能中使用不同的值。

   亲自试一试 - 实例    实例 1

为了更好地理解不同的定时函数值,这里提供了设置五个不同值的五个不同的 div 元素:

/* W3C 和 Opera: */#div1 {animation-timing-function: linear;} #div2 {animation-timing-function: ease;} #div3 {animation-timing-function: ease-in;} #div4 {animation-timing-function: ease-out;} #div5 {animation-timing-function: ease-in-out;}/* Firefox: */#div1 {-moz-animation-timing-function: linear;} #div2 {-moz-animation-timing-function: ease;} #div3 {-moz-animation-timing-function: ease-in;} #div4 {-moz-animation-timing-function: ease-out;} #div5 {-moz-animation-timing-function: ease-in-out;}/* Safari 和 Chrome: */#div1 {-webkit-animation-timing-function: linear;} #div2 {-webkit-animation-timing-function: ease;} #div3 {-webkit-animation-timing-function: ease-in;} #div4 {-webkit-animation-timing-function: ease-out;} #div5 {-webkit-animation-timing-function: ease-in-out;}

实例 2

与上例相同,但是通过 cubic-bezier 函数来定义速度曲线:

/* W3C 和 Opera: */#div1 {animation-timing-function: cubic-bezier(0,0,1,1);} #div2 {animation-timing-function: cubic-bezier(0.25,0.1,0.25,1);} #div3 {animation-timing-function: cubic-bezier(0.42,0,1,1);} #div4 {animation-timing-function: cubic-bezier(0,0,0.58,1);} #div5 {animation-timing-function: cubic-bezier(0.42,0,0.58,1);}/* Firefox: */#div1 {-moz-animation-timing-function: cubic-bezier(0,0,1,1);} #div2 {-moz-animation-timing-function: cubic-bezier(0.25,0.1,0.25,1);} #div3 {-moz-animation-timing-function: cubic-bezier(0.42,0,1,1);} #div4 {-moz-animation-timing-function: cubic-bezier(0,0,0.58,1);} #div5 {-moz-animation-timing-function: cubic-bezier(0.42,0,0.58,1);}/* Safari 和 Chrome: */#div1 {-webkit-animation-timing-function: cubic-bezier(0,0,1,1);} #div2 {-webkit-animation-timing-function: cubic-bezier(0.25,0.1,0.25,1);} #div3 {-webkit-animation-timing-function: cubic-bezier(0.42,0,1,1);} #div4 {-webkit-animation-timing-function: cubic-bezier(0,0,0.58,1);} #div5 {-webkit-animation-timing-function: cubic-bezier(0.42,0,0.58,1);}


CSS3 animation-delay 属性


   实例

等待两秒,然后开始动画:

div { animation-delay:2s; -webkit-animation-delay:2s; /* Safari 和 Chrome */}


   定义和用法

animation-delay 属性定义动画何时开始。

animation-delay 值以秒或毫秒计。

提示:允许负值,-2s 使动画马上开始,但跳过 2 秒进入动画。

默认值:0
继承性:no
版本:CSS3
JavaScript 语法:object.style.animationDelay="2s"

   语法

animation-delay: time;
描述测试
time可选。定义动画开始前等待的时间,以秒或毫秒计。默认值是 0。测试

   亲自试一试 - 实例

负值,请注意动画跳过 2 秒进入动画周期:

animation-delay: -2s /* W3C 和 Opera */-moz-animation-delay: -2s /* Firefox */-webkit-animation-delay: -2s /* Safari 和 Chrome */


CSS3 animation-iteration-count 属性


   实例

播放动画三次:

div { animation-iteration-count:3; -webkit-animation-iteration-count:3; /* Safari 和 Chrome */}


   定义和用法

animation-iteration-count 属性定义动画的播放次数。

默认值:1
继承性:no
版本:CSS3
JavaScript 语法:object.style.animationIterationCount=3

   语法

animation-iteration-count: n|infinite;
描述测试
n定义动画播放次数的数值。测试
infinite规定动画应该无限次播放。测试


CSS3 animation-direction 属性



   实例

暂停动画:

div { animation-direction:alternate; -webkit-animation-direction:alternate; /* Safari 和 Chrome */}


   定义和用法

animation-direction 属性定义是否应该轮流反向播放动画。

如果 animation-direction 值是 "alternate",则动画会在奇数次数(1、3、5 等等)正常播放,而在偶数次数(2、4、6 等等)向后播放。

注释:如果把动画设置为只播放一次,则该属性没有效果。

默认值:normal
继承性:no
版本:CSS3
JavaScript 语法:object.style.animationDirection="alternate"

   语法

animation-direction: normal|alternate;
描述测试
normal默认值。动画应该正常播放。测试
alternate动画应该轮流反向播放。测试