CSS3 Transition
浏览器支持
Internet Explorer 10, Firefox, Chrome和 Opera均支持这下面四个属性
但在Safari中,必须 通过私有属性 -webkit-t支持。
注意:Internet Explorer 9及更早IE版本不支持transition-timing-function 属性
transition : property duration timing-function delay;
transition主要包含四个属性值:
指定CSS属性的name:transition-property;
需要指定多少秒或毫秒才能完成:transition-duration;
在延续时间段,变换的速率变化transition-timing-function;
变换延迟时间transition-delay。
下面我们来分别介绍这四个属性
1、transition-property
transition-property: none|all|property;
- none 没有属性会获得过渡效果。
- all 所有属性都将获得过渡效果。
- property 定义应用过渡效果的 CSS 属性名称列表,多个以逗号分隔。
2、transition-duration
单位为s(秒)或者ms(毫秒)
注意:transition-duration属性必须指定值,否则持续时间为0,transition不会有任何效果。
3、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 之间的数值。
4、transition-delay
指定秒或毫秒数之前要等待切换效果开始,单位为秒(s)或毫秒(ms)
如果我们想改变两个或多个css属性,我们只需把几个transition的声明以列表的形式连在一起,用逗号(,)隔开,然后各自可以设置自己不同的延续时间等属性。
例子:
-moz-transition:width .8s linear,color .3s ease-in;
-webkit-transition:width .8s linear,color .3s ease-in;
-o-transition:width .8s linear,color .3s ease-in;
transition:width .8s linear,color .3s ease-in;
5、监听过渡结束
/*在jQuery中*/
$(element).on("webkitTransitionEnd mozTransitionEnd MSTransitionEnd oTransitionEnd animationend",fn());
/*原生js*/
element.addEventListener("webkitTransitionEnd",fn()) // Chrome, Safari 和 Opera
element.addEventListener("mozTransitionEnd",fn()) //标准写法