「CSS3 」动画详解_html/css_WEB-ITnose

php中文网
发布: 2016-06-21 09:07:33
原创
1128人浏览过

css3 提供给了我们非常多的转换函数:

  • 2D: translate, rotate, scale, skew.

  • 3D: translate3d, rotate3d, scale3d, skew3d.

只需要将这些函数作为transform属性的值,就可以设置相应的效果。

CSS3 动画则是将这些效果以及其他CSS属性按照你设定的方式来进行互相转变。

立即学习前端免费学习笔记(深入)”;

1. 动画相关属性

属性 描述
@keyframes 定义动画各个阶段的状态的代码段
animation 所有动画属性的简写属性,除了 animation-play-state 和 animation-fill-mode 属性。
animation-name 规定 @keyframes 动画的名称。
animation-duration 规定动画完成一个周期所花费的秒或毫秒。默认是 0。
animation-timing-function 规定动画的速度曲线。默认是 ease。
animation-delay 规定动画何时开始。默认是 0。
animation-iteration-count 规定动画被播放的次数。默认是 1。
animation-direction 规定动画是否在下一周期逆向地播放。默认是 normal。
animation-play-state 规定动画是否正在运行或暂停。默认是 running。
animation-fill-mode 规定元素在动画开始前和完成后的状态,默认是 none。

@keyframes

定义动画各个阶段的状态的代码段。比如开始态,结束态,中间态(使用百分比表示)。

@keyframes exampleName {    from {        transform: rotateY(0deg);        background: #000000;    }    50% {        transform: rotateY(180deg);        background: #00fa7e;    }    to {        transform: rotateY(0deg);        background: #008dff;    }}
登录后复制

animation-name

使用 @keyframes 定义的状态集合名称,如上面的 exampleName。

animation-duration

动画的周期时间。单位可以是秒(s),也可以是毫秒(ms)。

animation-timing-function

动画变化速度函数,有如下几种选项:

  • linear: 速度不变。

  • ease-in: 低速开始 ~ 正常速度。

  • ease-out: 正常速度 ~ 低速结束。

  • ease-in-out: 低速开始 ~ 正常速度 ~ 低速结束。

  • ease: 与 ease-in-out 基本相同,但是开始稍微比结束快一点儿。

  • cubic-bezier(x1, y1, x2, y2): 使用三次贝塞尔函数作为速度函数。

animation-delay

动画开始之前等待的时间。单位可以是秒(s),也可以是毫秒(ms)。

animation-iteration-count

动画的循环次数。可以是具体的次数,也可以是 infinite,表示无限循环播放。

animation-direction

动画循环的方向:

  • normal: 正向播放。

  • reverse: 反向播放。

  • alternate: 正向播放与反向播放交替进行。

animation

以上6个属性可以使用这一个属性来表示,格式为:

animate: name duration timing-function delay iteration-count direction;
登录后复制

animation-play-state

控制动画的状态,有播放(running)和暂停(paused)两种状态。

animation-fill-mode

规定元素在动画开始前和完成后的状态。

  • none: 元素在动画前后的状态和动画没有联系。

  • forwards: 动画完成后,元素保持动画最后的状态。

  • backwards: 动画开始前,元素保持动画开始的状态。

  • both: forwards 和 backwards 的结合。

2. transition

CSS3 除了 animation 相关的属性以外,还提供给我们一个 transition 属性,格式为:

transition: propertyName duration [timing-function] [delay], ...;
登录后复制

大家可能已经也看出来了,其实 transition 就是 @keyframes 只有 from 和 to 两个状态,并且播放次数为1,且不能暂停的 animation。

3. Demo

https://github.com/JasonKid/fezone/tree/master/CSS3/%E5%8A%A8%E7%94%BB%E8%AF%A6%E8%A7%A3

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号