这一篇文章的主要介绍的是CSS过渡和动画的相关属性。
CSS过渡
一、定义
transition属性: 可以为一个元素在不同状态之间切换的时候定义不同的过渡效果。是 transition-property,transition-duration,transition-timing-function 和 transition-delay 的一个简写属性。IE10支持,需要使用前缀-ms-。
二、transition属性说明
1) transition-property: 指定CSS属性的name,transition效果(要进行过渡的CSS属性)
2) transition-duration: transition效果需要指定多少秒或毫秒才能完成
3) transition-timing-function: 指定transition效果的转速曲线,也就是过渡时以什么速度进行过渡
其值为:
a.linear: 匀速
b.ease: 慢 -- 快 -- 慢
c.ease-in: 以慢开始
d.ease-out: 以慢结束
e.ease-in-out: 以慢速开始和结束
f.cubic-bezier(n,n,n):在cubic-bezier函数中定义自己的值,可能的值是0至1之间的数值 (贝塞尔曲线调试网站: https://cubic-bezier.com )
4) transition-delay: 定义transition效果开始的时候,也就是延迟多少秒后开始动画
三、语法
transition的语法: transition: property duration timing-function delay; 默认值为 transition: all 0 ease 0。
例:
.btn {
width: 300px;
height: 200px;
text-align: center;
line-height: 200px;
margin: auto;
background-color: yellowgreen;
transition: all .5s ease 0s;
}
.btn:hover {
background-color: lightblue;
border-radius: 50px;
}
参考内容:
菜鸟教程--CSS3transition属性
CSS3transition-timing-function属性
CSS动画
一、animation定义
animation: 用来指定一组或多组动画,每组之间用逗号相隔。它是 animation-name,animation-duration, animation-timing-function,animation-delay,animation-iteration-count,animation-direction,animation-fill-mode 和 animation-play-state 属性的一个简写属性形式。IE10支持。
二、animation语法
animation简写语法: animation: name duration timing-function delay iteration-count direction。默认值为 animation: none 0 ease 0 1 normal。
三、animation属性说明
1) animation-name: 绑定到选择器的keyframe名称
2) animation-duration: 完成动画所需要花费的时间,以秒或毫秒计
3) animation-timing-function: 动画的速度曲线,和transition-timing-function的取值一致
4) animation-delay: 在动画开始之前的延迟
5) animation-iteration-count: 规定动画应该播放的次数 (infinite)
6) animation-direction: 规定是否应该轮流反向播放动画 (normal: 默认值,正常播放; alternate:反向播放)
四、@keyframes规则的定义
@keyframes规则: 通过在动画序列中定义关键帧(或waypoints)的样式来控制CSS动画序列中的中间步骤。这比转换更能控制动画序列的中间步骤。帧数可以为百分比、from(等效于0%)、to(等效于100%)。IE10支持。
五、完整动画的使用案例
@keyframes show {
20% {
opacity: .3;
}
40% {
border-radius: 50px;
}
60% {
background-color: yellow;
}
}
/* transition 和 animation可以组合使用 */
@keyframes move {
0% {
left: -300px;
transition: left ease;
}
50% {
left: 150px;
transition: left linear;
}
100% {
left: 0px;
transition: left ease-out;
}
}
.btn1 {
animation: show 1s linear 1s infinite;
}
注: 重复定义的关键帧中,如果属性不同则会都生效,如果属性相同的话,那么以最后一次定义的属性为准。在关键帧中出现的!important关键词的属性将会被忽略。
参考内容:
W3school---CSS3 animation 属性
MDN--@keyframes
CSS动画优化
- 只允许改变
transform
、opacity
,其它属性不要动,避免重新计算布局(reflow) - 对动画元素应用
transform: translate3d(0, 0, 0)
、will-change: transform
等,开启硬件加速 - 动画元素尽量用
fixed
、absolute
定位方式,避免reflow - 对动画元素应用高一点的
z-index
,减少复合层数量
来源: css动画与gpu
推荐阅读:
CSS3 动画卡顿性能优化的完美解决方案
用CSS开启硬件加速来提高网站性能(转)
以上内容如有不对,希望大家指出,谢谢。