CSS transition-timing-function 属性

CSS 属性受到 transition effect的影响,会产生不断变化的中间值,而 CSS transition-timing-function 属性用来描述这个中间值是怎样计算的。实质上,通过这个函数会建立一条加速度曲线,因此在整个transition变化过程中,变化速度可以不断改变。


实例

以相同的速度从开始到结束的过渡效果:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. div
  6. {
  7. width:100px;
  8. height:100px;
  9. background:blue;
  10. transition:width 2s;
  11. transition-timing-function:linear;
  12. /* Firefox 4 */
  13. -moz-transition:width 2s;
  14. -moz-transition-timing-function:linear;
  15. /* Safari and Chrome */
  16. -webkit-transition:width 2s;
  17. -webkit-transition-timing-function:linear;
  18. /* Opera */
  19. -o-transition:width 2s;
  20. -o-transition-timing-function:linear;
  21. }
  22. div:hover
  23. {
  24. width:300px;
  25. }
  26. </style>
  27. </head>
  28. <body>
  29. <div></div>
  30. <p>请把鼠标指针移动到蓝色的 div 元素上,就可以看到过渡效果。</p>
  31. <p><b>注释:</b>本例在 Internet Explorer 中无效。</p>
  32. </body>
  33. </html>

浏览器支持

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

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

属性
transition-timing-function26.04.0 -webkit-10.016.04.0 -moz-6.13.1 -webkit-12.110.5 -o-

定义和用法

transition-timing-function 属性规定过渡效果的速度曲线。

该属性允许过渡效果随着时间来改变其速度。

可以规定多个 timing function ,通过使用 transition-property 属性,可以根据主列表( transition property 的列表)给每个CSS属性应用相应的 timing function 。如果 timing function 的个数比主列表中数量少,缺少的值被设置为初始值(ease) 。如果 timing function 比主列表要多,timing function 函数列表会被截断至合适的大小。这两种情况下声明的CSS属性都是有效的。

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

语法

  1. transition-timing-function: linear|ease|ease-in|ease-out|ease-in-out|cubic-bezier(n,n,n,n);
描述
linear规定以相同速度开始至结束的过渡效果(等于 cubic-bezier(0,0,1,1))。
ease规定慢速开始,然后变快,然后慢速结束的过渡效果(cubic-bezier(0.25,0.1,0.25,1))。
ease-in规定以慢速开始的过渡效果(等于 cubic-bezier(0.42,0,1,1))。
ease-out规定以慢速结束的过渡效果(等于 cubic-bezier(0,0,0.58,1))。
ease-in-out规定以慢速开始和结束的过渡效果(等于 cubic-bezier(0.42,0,0.58,1))。
cubic-bezier(n,n,n,n)在 cubic-bezier 函数中定义自己的值。可能的值是 0 至 1 之间的数值。

提示:请在实例中测试不同的值,这样可以更好地理解它们的工作原理。


- 实例

实例 1

为了更好地理解不同的函数值,请看下面带有五个不同值的五个不同的 div 元素:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. div {
  6. width: 100px;
  7. height: 50px;
  8. background: red;
  9. color: white;
  10. font-weight: bold;
  11. transition: width 2s;
  12. }
  13. #div1 {transition-timing-function: linear;}
  14. #div2 {transition-timing-function: ease;}
  15. #div3 {transition-timing-function: ease-in;}
  16. #div4 {transition-timing-function: ease-out;}
  17. #div5 {transition-timing-function: ease-in-out;}
  18. div:hover {
  19. width: 300px;
  20. }
  21. </style>
  22. </head>
  23. <body>
  24. <h2>transition-timing-function 属性</h2>
  25. <p><b>备注:</b> 此示例在 Internet Explorer 9 和早期版本中不起作用。</p>
  26. <div id="div1">linear</div>
  27. <div id="div2">ease</div>
  28. <div id="div3">ease-in</div>
  29. <div id="div4">ease-out</div>
  30. <div id="div5">ease-in-out</div>
  31. <p>将鼠标悬停在上面的div元素上,以查看不同的过渡效果。</p>
  32. </body>
  33. </html>
实例 2

与上例相同,但通过 cubic-bezier 来规定速度曲线:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <style>
  5. div {
  6. width: 100px;
  7. height: 50px;
  8. background: red;
  9. color: white;
  10. font-weight: bold;
  11. transition: width 2s;
  12. }
  13. #div1 {transition-timing-function: cubic-bezier(0,0,1,1);}
  14. #div2 {transition-timing-function: cubic-bezier(0.25,0.1,0.25,1);}
  15. #div3 {transition-timing-function: cubic-bezier(0.42,0,1,1);}
  16. #div4 {transition-timing-function: cubic-bezier(0,0,0.58,1);}
  17. #div5 {transition-timing-function: cubic-bezier(0.42,0,0.58,1);}
  18. div:hover {
  19. width: 300px;
  20. }
  21. </style>
  22. </head>
  23. <body>
  24. <h2>transition-timing-function 属性</h2>
  25. <p><b>备注:</b> 此示例在 Internet Explorer 9 和早期版本中不起作用。</p>
  26. <div id="div1">linear</div>
  27. <div id="div2">ease</div>
  28. <div id="div3">ease-in</div>
  29. <div id="div4">ease-out</div>
  30. <div id="div5">ease-in-out</div>
  31. <p>将鼠标悬停在上面的div元素上,以查看不同的过渡效果。</p>
  32. </body>
  33. </html>

分类导航