1.1实现过渡
CSS3 过渡是元素从一种样式逐渐改变为另一种的效果。
要实现这一点,必须规定两项内容:
- 指定要添加效果的CSS属性
- 指定效果的持续时间。
div {
width: 100px;
height: 100px;
background: red;
transition: width 2s;
-webkit-transition: width 2s;
-o-transition: width 2s;
}
如果未指定的期限,
transition
将没有任何效果,因为默认值是
0
。
定的
CSS
属性的值更改时效果会发生变化。一个典型
CSS
属性的变化是用户鼠标放在一个元素上时:
div:hover {
width: 200px;
}
示例效果如下:
1.2多项改变
要添加多个样式的变换效果,添加的属性由逗号分隔。
div.transition {
width: 100px;
height: 100px;
color: white;
text-align: center;
transform: rotateZ(0deg);
background: red;
transition: width 2s, height 2s, transform 2s;
-webkit-transition: width 2s, height 2s, transform 2s;
-o-transition: width 2s, height 2s, transform 2s;
}
div.transition:hover {
width: 300px;
height: 300px;
transform: rotateZ(45deg);
}
效果:
1.3速度曲线
transition-timing-function 属性规定过渡效果的速度曲线。
transition-timing-function 属性可接受以下值:
- ease - 规定过渡效果,先缓慢地开始,然后加速,然后缓慢地结束(默认)
- linear - 规定从开始到结束具有相同速度的过渡效果
- ease-in -规定缓慢开始的过渡效果
- ease-out - 规定缓慢结束的过渡效果
- ease-in-out - 规定开始和结束较慢的过渡效果
- cubic-bezier(n,n,n,n) - 允许您在三次贝塞尔函数中定义自己的值
不同的速度曲线:
div {
width: 200px;
height: 50px;
color: white;
text-align: center;
background: red;
transition: width 2s;
-webkit-transition: width 2s;
-o-transition: width 2s;
}
div:hover {
width: 300px;
}
.timing1 {
transition-timing-function: linear;
}
.timing2 {
transition-timing-function: ease;
}
.timing3 {
transition-timing-function: ease-in;
}
.timing4 {
transition-timing-function: ease-out;
}
.timing5 {
transition-timing-function: ease-in-out;
}
1.4延迟过渡效果
transition-delay
属性规定过渡效果的延迟(以秒计)。
下例在启动之前有
1
秒的延迟:
div {
transition-delay: 1s;
}
1.5简写属性
实例:
div {
transition-property: width;
transition-duration: 2s;
transition-timing-function: linear;
transition-delay: 2s;
}
以上样式可简写为:
div {
transition: width 2s linear 2s;
}