CSS3 transition-timing-function 属性 | CSS3教程:CSS3过渡

返回到:CSS3过渡 | CSS3教程

属性定义及使用说明

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

浏览器支持

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

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

属性谷歌IE火狐苹果opera
transition-timing-function26.0
4.0 -webkit-
10.016.0
4.0 -moz-
6.1
3.1 -webkit-
12.1
10.5 -o-

实例

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

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"> 
<title>Web176教程网(web176.com)</title>
<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>

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

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"> 
<title>Web176教程网(web176.com)</title>
<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"> 
<title>Web176教程网(web176.com)</title>
<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>

作者:terry,如若转载,请注明出处:https://www.web176.com/css3transition/5087.html

(0)
打赏 支付宝 支付宝 微信 微信
terryterry
上一篇 2022年1月10日 下午3:46
下一篇 2022年1月10日 下午5:27

相关推荐

发表回复

登录后才能评论