transition
通过 CSS3,我们可以在不使用 Flash 动画或 JavaScript 的情况下,当元素从一种样式变换为另一种样式时为元素添加效果。
注释:Internet Explorer 9 以及更早的版本,不支持 transition 属性。
CSS3 过渡是元素从一种样式逐渐改变为另一种的效果。
要实现这一点,必须规定两项内容:
1.规定您希望把效果添加到哪个 CSS 属性上
2.规定效果的时长
transition 属性是一个简写属性,用于设置四个过渡属性:
transition-property 规定设置过渡效果的 CSS 属性的名称。
transition-duration 规定完成过渡效果需要多少秒或毫秒。 默认是 0。
transition-timing-function 规定速度效果的速度曲线。 默认是 "ease"。
transition-delay 定义过渡效果何时开始。 默认是 0。
注释:请始终设置 transition-duration 属性,否则时长为 0,就不会产生过渡效果。
过渡效果是需要之前已经定义好了属性,过渡效果通过触发来应用,比如:hover, :focus, and :active等
语法: trJansition: property duration timing-function delay;
JavaScript语法:object.style.transition="width 2s"
transition-property CSS属性的名称
属性: none:没有属性会获得过渡效果。
all:所有属性都会获得过渡效果。
JavaScript语法:object.style.transitionProperty="width,height"
transition-duration 过渡时间
给一个具体时间 多少秒或毫秒
比如:transition-duration:3s;
JavaScript 语法: object.style.transitionDuration="5s"
transition-timing-function 过渡方式
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 之间的数值。
JavaScript语法:object.style.transitionTimingFunction="linear"
transition-delay 延迟时间。
transition-delay 值以秒或毫秒计。
如果为负值则直接开始过渡效果
JavaScript语法:object.style.transitionDelay="2s"
写的一个小案例
![在这里插入图片描述](https://i-blog.csdnimg.cn/blog_migrate/9feab0677aa706d8a69815c9795bfccd.jpeg)
transition 还可以和 CSS3 转换 transform一起使用 ransition 做不到的可以用CSS动画animation 做到