本篇讲解CSS的过渡动画如何实现。
transition
transition 属性是一个简写属性,用于设置四个过渡属性
:
- transition-property
- transition-duration
- transition-timing-function
- transition-delay
div{
transition: property duration timing-function delay;
}
transition 值 | 作用 |
---|---|
transition-property | 规定设置过渡效果的 CSS 属性的名称 |
transition-duration | 规定完成过渡效果需要多少秒或毫秒 |
transition-timing-function | 规定速度效果的速度曲线 |
transition-delay | 定义过渡效果何时开始 |
transition-property
规定应用过渡效果的 CSS 属性的名称。
div{
transition-property: none|all|property;
}
transition-property 值 | 作用 |
---|---|
none | 没有属性会获得过渡效果 |
all | 所有属性都将获得过渡效果 |
property | 定义应用过渡效果的 CSS 属性名称列表,列表以逗号分隔 |
transition-duration
规定完成过渡效果需要花费的时间(以秒或毫秒计)。
div{
transition-duration: 5s;
}
transition-delay
规定过渡效果多久之后开始(以秒或毫秒计)。
div{
transition-delay: 3s;
}
transition-timing-function
规定过渡效果的速度曲线。
div{
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 之间的数值。 |
transition与animation的区别
transition
是过渡属性
,需要用户自行触发,比如:点击,鼠标悬浮等。
animation
是动画属性
,不需要用户触发,网页加载完成后自动执行。
暂无评论