千家信息网

css3动画属性Transition怎么用

发表于:2024-11-17 作者:千家信息网编辑
千家信息网最后更新 2024年11月17日,这篇文章给大家分享的是有关css3动画属性Transition怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。transition:[ transition-prope
千家信息网最后更新 2024年11月17日css3动画属性Transition怎么用

这篇文章给大家分享的是有关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 | [ ] [ ',' ]*

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

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

三、transition-timing-function

语法:

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

cubic-bezier(, , , ) [, ease | linear | ease-in |

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

取值:

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

transition-delay是用来指定一个动画开始执行的时间,也就是说当改变元素属性值后多长时间开始执行transition效果,取 值:为数值,单位为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已经支持属性了。

感谢各位的阅读!关于"css3动画属性Transition怎么用"这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

0