CSS3中的动画功能——Transitions 功能与Animations 功能

1 Transitions功能

(1)浏览器支持:

到目前为止:Safari3.1以上、Chrome8以上、Firefox4以上、Opera10以上、IE11以上浏览器支持该功能。 

(2)功能

在CSS3中,Transitions功能通过将元素的某个属性从一个属性值在指定的时间内平滑过渡到另一个属性值来实现动画功能。

(3)使用方法

transition:property duration timing-function

property:表示对哪个属性进行平滑过渡。

duration:表示在多久时间内完成属性值得平滑过渡。

timing-function:表示通过什么方法进行平滑过渡。

div{

background-color:#ffff00;

transition:background-color 1s linear;//在1秒内让div元素的背景色从黄色平滑过渡到浅蓝色。

}

div{

background-color:#00ffff;

}

(4)另一种使用方法

transition-property:background-color;

transition-duration:1;

transition-timing-function:linear;

(5)transition-delay属性

指定变换动画特效延迟多久后开始执行。可以用秒单位或毫秒单位指定属性值。

transition-delay:1s;

//或 transition:background-color 1s linear 2s;(在第四个参数中书写延迟时间)

(6)使用Transitions功能同时平滑过渡多个属性值

transition:background-color 1s linear,color 1s linear,width 1s linear;

(7)移动、旋转等动画效果

img{

position:absolute;top:70px;left:0;

transform:rotate(0deg);

transition:left 1s linear,transform 1s linear;

}

 img:hover{

left:30px;

transform:rotate(720deg);

}

(8)缺点

只能指定属性的开始值与终点值,然后再这两个属性值之间实现平滑过渡,不能实现更为复杂的动画效果。

2 Animations功能

(1)浏览器支持:

到目前为止:Safari4以上、Chrome2以上、Firefox20以上、Opera18以上、IE11以上浏览器支持该功能。 

(2)功能

与Transitions功能相同,都是通过改变元素的属性值来实现动画效果。

区别:Animations功能通过定义多个关键帧以及定义每个关键帧中元素的属性值来实现更为复杂的动画效果。

(3)创建关键帧的集合

@keyframes 关键帧集合名{  创建关键帧的代码  }

(4)创建关键帧的代码(类似如下)

40%{ 本关键帧中的样式代码 }

(40%表示改帧位于整个动画过程中的40%处,开始帧为0%,结束帧为100%)

@keyframes mycolor{

0%{

background-color:red;

}

40%{

background-color:darkblue;

}

70%{

background-color:yellow;

}

100%{

background-color:red;

}

}

(5)在元素的样式中使用该关键帧的集合

div{

animation-name:my-color; //指定关键帧集合的名称

animation-duration:5s; //指定完成整个动画所花费的时间

animation-timing-function:linear; //指定实现动画的方法

}

(6)其他属性

animation-delay:用于指定延迟多少秒或毫秒后开始执行动画。

animation-iteration-count:用于指定动画的执行次数,可指定为infinite(无限次)。

animation-direction:用于指定动画的执行方向。可指定属性值包括:

  • normal:初始值(动画执行完毕后返回初始状态)
  • alternate:交替更换动画的执行方向
  • reverse:反方向执行动画
  • alternate-reverse:从反方向开始交替更改动画的执行方向

(7)在一行样式代码中定义animation动画时采用如下所示的书写方式

animation:keyframe的名称 动画的执行时长 动画的实现方法  延迟多少秒后开始执行动画 动画的执行次数 动画的执行方向;

(8)实现多个属性值同时改变的动画

只需只在各关键帧中同时指定这些属性值就可以了。

3 实现动画的方法

方法属性值的变化速度
linear在动画开始时与结束时以同样速度进行改变
ease-in动画开始时速度很,然后速度沿曲线值进行加快
ease-out动画开始时速度很,然后速度沿曲线值进行放慢
ease动画开始时速度很,然后速度沿曲线值进行加快,然后再沿曲线值进行放慢
ease-in-out动画开始时速度很,然后速度沿曲线值进行加快,然后再沿曲线值进行放慢

4 实现网页的淡入效果

通过在开始帧与结束帧中改变页面的opacity属性的属性值来实现页面的淡入效果。

@keyframes fadein{

0%{

opacity:0;

background-color:white;

}

100%{

opacity:1;

background-color:white;

}

body{

animation-name: fadein; 

animation-duration:5s; 

animation-timing-function:linear; 

animation-iteration-count:1;

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值