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>