CSS animation-timing-function 属性

CSS animation-timing-function 属性定义CSS动画在每一动画周期中执行的节奏。可能值为一或多个 <timing-function>。

对于关键帧动画来说,timing function 作用于一个关键帧周期而非整个动画周期,即从关键帧开始开始,到关键帧结束结束。

定义于一个关键帧区块的缓动函数(animation timing function)应用到改关键帧;另外,若该关键帧没有定义缓动函数,则使用定义于整个动画的缓动函数。


实例

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

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. div
  6. {
  7. width:100px;
  8. height:100px;
  9. background:red;
  10. position:relative;
  11. animation:mymove 5s infinite;
  12. animation-timing-function:linear;
  13. /* Safari and Chrome */
  14. -webkit-animation:mymove 5s infinite;
  15. -webkit-animation-timing-function:linear;
  16. }
  17. @keyframes mymove
  18. {
  19. from {left:0px;}
  20. to {left:200px;}
  21. }
  22. @-webkit-keyframes mymove /* Safari and Chrome */
  23. {
  24. from {left:0px;}
  25. to {left:200px;}
  26. }
  27. </style>
  28. </head>
  29. <body>
  30. <p><strong>注释:</strong>Internet Explorer 9 以及更早的版本不支持 animation-timing-function 属性。</p>
  31. <div></div>
  32. </body>
  33. </html>

浏览器支持

表格中的数字注明了完全支持该属性的首个浏览器版本。

带 -webkit-、-moz- 或 -o- 的数字表示使用前缀的首个版本。

属性
animation-timing-function43.04.0 -webkit-10.016.05.0 -moz-9.04.0 -webkit-30.015.0 -webkit-12.0 -o-

定义和用法

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

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

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

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

语法

  1. 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 元素:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. div
  6. {
  7. width:100px;
  8. height:50px;
  9. background:red;
  10. color:white;
  11. font-weight:bold;
  12. position:relative;
  13. animation:mymove 5s infinite;
  14. -webkit-animation:mymove 5s infinite; /* Safari and Chrome */
  15. }
  16. #div1 {animation-timing-function:linear;}
  17. #div2 {animation-timing-function:ease;}
  18. #div3 {animation-timing-function:ease-in;}
  19. #div4 {animation-timing-function:ease-out;}
  20. #div5 {animation-timing-function:ease-in-out;}
  21. /* Safari and Chrome: */
  22. #div1 {-webkit-animation-timing-function:linear;}
  23. #div2 {-webkit-animation-timing-function:ease;}
  24. #div3 {-webkit-animation-timing-function:ease-in;}
  25. #div4 {-webkit-animation-timing-function:ease-out;}
  26. #div5 {-webkit-animation-timing-function:ease-in-out;}
  27. @keyframes mymove
  28. {
  29. from {left:0px;}
  30. to {left:300px;}
  31. }
  32. @-webkit-keyframes mymove /* Safari and Chrome */
  33. {
  34. from {left:0px;}
  35. to {left:300px;}
  36. }
  37. </style>
  38. </head>
  39. <body>
  40. <p><strong>注释:</strong>Internet Explorer 9 以及更早的版本不支持 animation-timing-function 属性。</p>
  41. <div id="div1">linear</div>
  42. <div id="div2">ease</div>
  43. <div id="div3">ease-in</div>
  44. <div id="div4">ease-out</div>
  45. <div id="div5">ease-in-out</div>
  46. </body>
  47. </html>
实例 2

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

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. div
  6. {
  7. width:100px;
  8. height:50px;
  9. background:red;
  10. color:white;
  11. font-weight:bold;
  12. position:relative;
  13. animation:mymove 5s infinite;
  14. -webkit-animation:mymove 5s infinite; /* Safari and Chrome */
  15. }
  16. #div1 {animation-timing-function:cubic-bezier(0,0,0.25,1);}
  17. #div2 {animation-timing-function:cubic-bezier(0.25,0.1,0.25,1);}
  18. #div3 {animation-timing-function:cubic-bezier(0.42,0,1,1);}
  19. #div4 {animation-timing-function:cubic-bezier(0,0,0.58,1);}
  20. #div5 {animation-timing-function:cubic-bezier(0.42,0,0.58,1);}
  21. /* Safari and Chrome: */
  22. #div1 {-webkit-animation-timing-function:cubic-bezier(0,0,1,1);}
  23. #div2 {-webkit-animation-timing-function:cubic-bezier(0.25,0.1,0.25,1);}
  24. #div3 {-webkit-animation-timing-function:cubic-bezier(0.42,0,1,1);}
  25. #div4 {-webkit-animation-timing-function:cubic-bezier(0,0,0.58,1);}
  26. #div5 {-webkit-animation-timing-function:cubic-bezier(0.42,0,0.58,1);}
  27. @keyframes mymove
  28. {
  29. from {left:0px;}
  30. to {left:300px;}
  31. }
  32. @-webkit-keyframes mymove /* Safari and Chrome */
  33. {
  34. from {left:0px;}
  35. to {left:300px;}
  36. }
  37. </style>
  38. </head>
  39. <body>
  40. <p><strong>注释:</strong>Internet Explorer 9 以及更早的版本不支持 animation-timing-function 属性。</p>
  41. <div id="div1">linear</div>
  42. <div id="div2">ease</div>
  43. <div id="div3">ease-in</div>
  44. <div id="div4">ease-out</div>
  45. <div id="div5">ease-in-out</div>
  46. </body>
  47. </html>

相关页面

CSS3 教程:CSS3 动画

分类导航