codecamp

CSS3 Transition

W3C标准中对css3的transition这是样描述的:“css的transition允许css的属性值在一定的时间区间内平滑地过渡。这种效果可以在鼠标单击、获得焦点、被点击或对元素任何改变中触发,并圆滑地以动画效果改变CSS的属性值。”

浏览器支持

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 属性名称列表,多个以逗号分隔。

可用的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())  //标准写法



CSS3 Transform 2D和3D转换
CSS3 Background
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }