CSS3 transition-timing-function 属性

转场效果以同样的速度从开始到结束:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <style>
    div {
      width: 100px;
      height: 100px;
      background: red;
      transition: width 2s;
      transition-timing-function: linear;
      /* Safari */
      -webkit-transition: width 2s;
      -webkit-transition-timing-function: linear;
    }

    div:hover {
      width: 300px;
    }
  </style>
</head>
<body>

  <p><b>注意:</b> 该属性不兼容IE 9 以及更早版本的浏览器.</p>

  <div></div>

  <p>将鼠标移动至块上查看过渡动画效果.</p>

</body>
</html>

尝试一下 »


浏览器支持

表格中的数字表示支持该属性的第一个浏览器版本号。

紧跟在 -webkit-, -ms- 或 -moz- 前的数字为支持该前缀属性的第一个浏览器版本号。

属性
transition-timing-function 26.0
4.0 -webkit-
10.0 16.0
4.0 -moz-
6.1
3.1 -webkit-
12.1
10.5 -o-

属性定义及使用说明

transition-timing-function属性指定切换效果的速度。

此属性允许一个过渡效果,以改变其持续时间的速度。

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

语法

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 之间的数值。

Tip: Try the different values in the examples below to understand how it works!


更多实例


为了更好地理解不同的函数值:这里有五个不同的div元素,用5个不同的值:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <style>
    div {
      width: 100px;
      height: 50px;
      background: red;
      color: white;
      font-weight: bold;
      transition: width 2s;
      -webkit-transition: width 2s;
      /* Safari */
    }

    #div1 {
      transition-timing-function: linear;
    }

    #div2 {
      transition-timing-function: ease;
    }

    #div3 {
      transition-timing-function: ease-in;
    }

    #div4 {
      transition-timing-function: ease-out;
    }

    #div5 {
      transition-timing-function: ease-in-out;
    }
    /* Safari */

    #div1 {
      -webkit-transition-timing-function: linear;
    }

    #div2 {
      -webkit-transition-timing-function: ease;
    }

    #div3 {
      -webkit-transition-timing-function: ease-in;
    }

    #div4 {
      -webkit-transition-timing-function: ease-out;
    }

    #div5 {
      -webkit-transition-timing-function: ease-in-out;
    }

    div:hover {
      width: 300px;
    }
  </style>
</head>
<body>

  <p><b>注意:</b> 该属性不兼容 IE 9 以及更早版本的浏览器</p>

  <div id="div1" style="top:100px">linear</div>
  <div id="div2" style="top:150px">ease</div>
  <div id="div3" style="top:200px">ease-in</div>
  <div id="div4" style="top:250px">ease-out</div>
  <div id="div5" style="top:300px">ease-in-out</div>

  <p>将鼠标移动至块上查看过渡动画效果.</p>

</body>
</html>

尝试一下 »


和上面的例子一样,但指定速度曲线立方贝塞尔曲线函数:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <style>
    div {
      width: 100px;
      height: 50px;
      background: red;
      color: white;
      font-weight: bold;
      transition: width 2s;
      -webkit-transition: width 2s;
      /* Safari */
    }

    #div1 {
      transition-timing-function: cubic-bezier(0, 0, 0.25, 1);
    }

    #div2 {
      transition-timing-function: cubic-bezier(0.25, 0.1, 0.25, 1);
    }

    #div3 {
      transition-timing-function: cubic-bezier(0.42, 0, 1, 1);
    }

    #div4 {
      transition-timing-function: cubic-bezier(0, 0, 0.58, 1);
    }

    #div5 {
      transition-timing-function: cubic-bezier(0.42, 0, 0.58, 1);
    }
    /* Safari */

    #div1 {
      -webkit-transition-timing-function: cubic-bezier(0, 0, 0.25, 1);
    }

    #div2 {
      -webkit-transition-timing-function: cubic-bezier(0.25, 0.1, 0.25, 1);
    }

    #div3 {
      -webkit-transition-timing-function: cubic-bezier(0.42, 0, 1, 1);
    }

    #div4 {
      -webkit-transition-timing-function: cubic-bezier(0, 0, 0.58, 1);
    }

    #div5 {
      -webkit-transition-timing-function: cubic-bezier(0.42, 0, 0.58, 1);
    }

    div:hover {
      width: 300px;
    }
  </style>
</head>
<body>

  <p><b>注意:</b> 该属性不兼容IE 9以及更早版本的浏览器</p>

  <div id="div1" style="top:100px">linear</div>
  <div id="div2" style="top:150px">ease</div>
  <div id="div3" style="top:200px">ease-in</div>
  <div id="div4" style="top:250px">ease-out</div>
  <div id="div5" style="top:300px">ease-in-out</div>

  <p>将鼠标移动至块上查看过渡动画效果.</p>

</body>
</html>

尝试一下 »