欢迎来到DIVCSS5查找CSS资料与学习DIV CSS布局技术!
您的位置:DIVCSS5首页 > CSS3 >

深入学习css3动画属性Transition

transition[ transition-property ] || [ transition-duration ] || [ transition-timing-function ] || [ transition-delay ]

 

默认值:看每个独立属性

 

取值:

 

[ transition-property ]:检索或设置对象中的参与过渡的属性

[ transition-duration ]:检索或设置对象过渡的持续时间

[ transition-timing-function ]:检索或设置对象中过渡的动画类型

[ transition-delay ]:检索或设置对象延迟过渡的时间

看完这个我就觉得这个玩意跟css中的border是差不多类似的写法的。

实例在这里:http://codepen.io/kujian/pen/DreiE

例如:

transition:color 0.2s easy-in-out .1s;

这个就是缩写起来的写法了。

那么如果你要拆开来怎么办呢?

 

transition-property:color; transition-duration:.2s; transition-timing-function:ease-in-out; transition-delay:.1s; 这种写法就跟我刚才说到的border是差不多的,就是把效果拆出来,这样子实现了多种效果同时响应。当然定义不同的速率和显示的间隔也会有精彩的结果哦。 transition:color .5s ease-in .1s, background-color .5s ease-in .1s, color .5s ease-in .1s; 拆出来就是下面这样子了。

 

transition-property:color, background-color, color; transition-duration:.5s, .5s, .5s; transition-timing-function:ease-in, ease-in, ease-in; transition-delay:.1s, .1s, .1s;

 

关于transition-property的取值如下:(基本是css属性都能用了)

 

transition-property none | all | [ <IDENT> ] [ ',' <IDENT> ]*

 

transition-property是用来指定当元素其中一个属性改变时执行transition效果,其主要有以下几个值:none(没有属 性改 )all(所有属性改变)这个也是其默认值;indent(元素属性名);当其值为none时,transition马上停止执行,当指定为all 时,则元素产生任何属性值变化时都将执行transition效果,ident是可以指定元素的某一个属性值。其对应的类型如下:

 

1color 通过红、绿、蓝和透明度组件变换(每个数值单独处理),如:background-colorborder-colorcoloroutline-colorCSS属性;

 

2length:真实的数字,如:word-spacingwidthvertical- aligntoprightbottomleftpaddingoutline-widthmarginmin-widthmin- heightmax-widthmax-heightline-heightheightborder-widthborder- spacingbackground-position等属性;

 

3percentage:真实的数字,如:word-spacingwidthvertical- aligntoprightbottomleftmin-widthmin- heightmax-widthmax-heightline-heightheightbackground-position等属性;

 

4integer离散步骤(整个数字),在真实的数字空间,以及使用floor()转换为整数时发生,如:outline-offsetz-index等属性;

 

5number真实的(浮点型)数值,如:zoomopacityfont-weight等属性;

 

6transform list:详情请参阅:《CSS3 Transform》。

 

7rectangle:通过x y widthheight(转为数值)变换,如:crop

 

8visibility:离散步骤,在01数字范围之内,0表示“隐藏”,1表示完全“显示”,如:visibility

 

9shadow:作用于colorxy、和blur(模糊)属性,如:text-shadow

 

10gradient:通过每次停止时的位置和颜色进行变化。它们必须有相同的类型(放射状的或是线性的)和相同的停止数值以便执行动画,如:background-image

 

11paint server (SVG):只支持下面的情况:从gradientgradient以及colorcolor,然后工作与上面类似;

 

12space-separated list of above:如果列表有相同的项目数值,则列表每一项按照上面的规则进行变化,否则无变化;

 

13a shorthand property:如果缩写的所有部分都可以实现动画,则会像所有单个属性变化一样变化。

 

具体什么CSS属性可以实现transition效果,在W3C官网中列出了所有可以实现transition效果的CSS属性值以及值的类型,大家可以点这里了解详情。这里需要提醒一点是,并不是什么属性改变都为触发transition动作效果,比如页面的自适应宽度,当浏览器改变宽度时,并不会触发transition的效果。但上述表格所示的属性类型改变都会触发一个transition动作效果。

transition-duration <time> [, <time>]*

 

transition-duration是用来指定元素 转换过程的持续时间,取值:<time>为数值,单位为s(秒),可以作用于所有元素,包括:before:after伪元素。其默认值是0,也就是变换时是即时的。

三、transition-timing-function

 

语法:

 

transition-timing-function ease | linear | ease-in | ease-out | ease-in-out |

cubic-bezier(<number>, <number>, <number>, <number>) [, ease | linear | ease-in |

ease-out | ease-in-out | cubic-bezier(<number>, <number>, <number>, <number>)]*

 

取值:

 

transition-timing-function的值允许你根据时间的推进去改变属性值的变换速率,transition-timing-function6个可能值:

 

1ease:(逐渐变慢)默认值,ease函数等同于贝塞尔曲线(0.25, 0.1, 0.25, 1.0)

 

2linear:(匀速),linear 函数等同于贝塞尔曲线(0.0, 0.0, 1.0, 1.0)

 

3ease-in(加速)ease-in 函数等同于贝塞尔曲线(0.42, 0, 1.0, 1.0)

 

4ease-out:(减速),ease-out 函数等同于贝塞尔曲线(0, 0, 0.58, 1.0)

 

5ease-in-out:(加速然后减速),ease-in-out 函数等同于贝塞尔曲线(0.42, 0, 0.58, 1.0)

 

6cubic-bezier:(该值允许你去自定义一个时间曲线), 特定的cubic-bezier曲线。 (x1, y1, x2, y2)四个值特定于曲线上点P1和点P2。所有值需在[0, 1]区域内,否则无效。

 

其是cubic-bezier为通过贝赛尔曲线来计算“转换”过程中的属性值,如下曲线所示,通过改变P1(x1, y1)P2(x2, y2)的坐标可以改变整个过程的Output Percentage。初始默认值为default

 

其他几个属性的示意图:

四、transition-delay:

 

语法:

transition-duration <time> [, <time>]*transition-delay <time> [, <time>]*

 

transition-delay是用来指定一个动画开始执行的时间,也就是说当改变元素属性值后多长时间开始执行transition效果,取 值:<time>为数值,单位为s(秒),它的使用和transition-duration极其相似,也可以作用于所有元素,包 :before:after伪元素。 默认大小是”0″,也就是变换立即执行,没有延迟。

 

对了,最后一个,这玩意,不同浏览器还有有各自的私有属性在里面。

p {

-webkit-transition: all .5s ease-in-out 1s;

-o-transition: all .5s ease-in-out 1s;

-moz-transition: all .5s ease-in-out 1s;

transition: all .5s ease-in-out 1s;

}

ie10已经支持属性了。

如需转载,请注明文章出处和来源网址:http://www.divcss5.com/css3-style/c23587.shtml

我要分享到:

必备CSS教程 Essential CSS Tutorials

必备HTML基础教程 Essential HTML Tutorials

如对文章有任何疑问请提交到DIV CSS论坛,或有任何网页制作CSS问题立即到CSS论坛发贴求解 或 直接DIVCSS5网页顶部搜索遇到DIVCSS疑问。
CSS教程文章修订日期:2017-04-17 08:24 原创:DIVCSS5
本文www.divcss5.com DIVCSS5版权所有。