CSS3动画基础——元素过渡
css3,过渡,动画2016-11-23
过渡动画是动画的基础
在学习动画属性之前
我们需要先了解过渡属性transition
先来看一个小例子
<div class="demo"></div>
.demo {
width: 100px;
height: 100px;
background-color: royalblue;
}
.demo:hover {
width: 200px;
}
这样当我的光标悬浮在demo的一瞬间
它的宽度变成了200px
有没有办法让我们光标悬浮在元素时,元素宽度缓慢变宽呢
在CSS3之前我们只能使用麻烦的js脚本
但是现在我们只需要添加一个属性
就可以达到我们的目的
.demo {
width: 100px;
height: 100px;
background-color: royalblue;
transition: width 1s; /*增*/
}
.demo:hover {
width: 200px;
}
transition它的作用就是指定当你的元素某些样式发生变化时
这些样式可以渐渐过渡到最终属性值
它是一个复合属性
有以下子属性
transition-property 我们想要哪种属性过渡就写哪种属性
或者干脆写过渡所有属性的关键字all
transition-duration渐变时间属性值就是“数字+s”
代表几秒钟内过渡
transition-timing-function 是可选的属性值,有如下可选值
大多我们都用不上,最常用的大概就是我们默认的ease和线性过渡linear了
transition-delay 同样是可选属性值
如果你想要延迟过渡,换句话说如果我们想要在过渡前停一小会儿
那么就在这个复合属性的最后添加我们需要延迟的时间“数字+s”
这个属性可以对多个不同的属性进行设置
我们要做的就是使用逗号隔开
.demo {
width: 100px;
height: 100px;
background-color: royalblue;
transition: width 1s linear,
height 1s linear,
background-color 2s 1s; /*改*/
}
.demo:hover {
width: 200px;
height: 200px;
background-color: lawngreen; /*改*/
}
鼠标移出元素后,元素又过渡回来
使用过渡属性而不是脚本的另一个原因是
脚本方法改变多个元素样式可能会产生冲突
解决的办法是使用bool变量加锁,还是很麻烦
我们的transition过渡属性就不需要考虑这么多
元素与元素之间互不影响
还有一点要注意,元素过渡需要知道样式具体的起始属性和末尾属性
比如说我们例子中的width明确了从100px过渡到200px
.demo:hover {
width: auto; /*改*/
height: 200px;
background-color: lawngreen; /*改*/
}
改变了悬浮样式width为auto
我们发现当光标悬浮元素后
width属性并没有发生过渡
当然也不是所有的样式都可以过渡
比如说你想让 display:block
过渡到 display:inline-block
那是不可能的
有以下属性参与过渡
可以看到这个属性真的是十分强大