目录
一、CSS3 过渡
二、它是如何工作?
三、过渡属性
CSS3中;我们为了添加某种效果可以从一种样式转变到另一个的时候;无需使用flash动画或JavaScript。
CSS3 过渡是元素从一种样式逐渐改变为另一种的效果。
要实现这一点;必须规定两项内容;
指定要添加效果的CSS属性指定效果的持续时间。应用于宽度属性的过渡效果;时长为 2 秒;
div { transition: width 2s; -webkit-transition: width 2s; /* Safari */ }
注意; 如果未指定的期限;transition将没有任何效果;因为默认值是0。
指定的CSS属性的值更改时效果会发生变化。一个典型CSS属性的变化是用户鼠标放在一个元素上时;
<style>
div
{
width:100px;
height:100px;
background:red;
transition:width 2s;
-webkit-transition:width 2s; /* Safari */
}
div:hover
{
width:300px;
}
</style>
</head>
<body>
<p><b>注意;</b>该实例无法在 Internet Explorer 9 及更早 IE 版本上工作。</p>
<div></div>
<p>鼠标移动到 div 元素上;查看过渡效果。</p>
</body>
</html>
要添加多个样式的变换效果;添加的属性由逗号分隔;
添加了宽度;高度和转换效果;
<style>
div {
width: 100px;
height: 100px;
background: red;
-webkit-transition: width 2s, height 2s, -webkit-transform 2s; /* For Safari 3.1 to 6.0 */
transition: width 2s, height 2s, transform 2s;
}
div:hover {
width: 200px;
height: 200px;
-webkit-transform: rotate(180deg); /* chrome, Safari, Opera */
transform: rotate(180deg);
}
</style>
</head>
<body>
<p><b>注意;</b>该实例无法在 Internet Explorer 9 及更早 IE 版本上工作。</p>
<div>鼠标移动到 div 元素上;查看过渡效果。</div>
</body>
</html>
下表列出了所有的过渡属性:
下面的两个例子设置所有过渡属性;
在一个例子中使用所有过渡属性;
<style>
div
{
width:100px;
height:100px;
background:red;
transition-property:width;
transition-duration:1s;
transition-timing-function:linear;
transition-delay:2s;
/* Safari */
-webkit-transition-property:width;
-webkit-transition-duration:1s;
-webkit-transition-timing-function:linear;
-webkit-transition-delay:2s;
}
div:hover
{
width:200px;
}
</style>
</head>
<body>
<p><b>注意;</b>该实例无法在 Internet Explorer 9 及更早 IE 版本上工作。</p>
<div></div>
<p>鼠标移动到 div 元素上;查看过渡效果。</p>
<p><b>注意;</b> 过渡效果需要等待两秒后才开始。</p>
</body>
</html>
与上面的例子相同的过渡效果;但是使用了简写的 transition 属性;
<style>
div
{
width:100px;
height:100px;
background:red;
transition:width 1s linear 2s;
/* Safari */
-webkit-transition:width 1s linear 2s;
}
div:hover
{
width:200px;
}
</style>
</head>
<body>
<p><b>注意;</b>该实例无法在 Internet Explorer 9 及更早 IE 版本上工作。</p>
<div></div>
<p>鼠标移动到 div 元素上;查看过渡效果。</p>
<p><b>注意;</b> 过渡效果需要等待两秒后才开始。</p>
</body>
</html>