CSS3动画属性 animation详解(看完就会)

简介: CSS3动画属性 animation详解(看完就会)

keyframes

用 keyframes定义动画,写上动画要执行的内容, (类似类选择器)

@keyframes a {
            0% {
                width: 300px;
            }
            100% {
                width: 600px;
            }
        }

image.gif

这就是定义了一个动画变量名,从0%到100%也就是从开始到结束,也可以用from,to来表示,

@keyframes a {
            from {
                width: 300px;
            }
            to {
                width: 600px;
            }
        }

image.gif

里面写属性变化的值,不止可以分两个段也可以进行多段分割

@keyframes a {
            0% {
                width: 300px;
            }
            50% {
                width: 800px;
            }
            100% {
                width: 300px;
            }
        }

image.gif

,用百分数进行分割。

动画相关的值

@keyframes 规定动画

animation-name 规定 @keyframes 动画的名称(必须的)

animation-duration 规定动画完成一个周期所花费的秒或毫秒,默认是 0(必须的)

animation-timingfunction  规定动画的速度曲线,默认是“ease”

animation-delay 规定动画何时开始,默认是 0

animation-iteration-count 规定动画被播放的次数,默认是 1,还有 infinite

animation-direction 规定动画是否在下一周期逆向播放,默认是 "normal", alternate 逆播放

animation-play-state 规定动画是否正在运行或暂停。默认是 "running", 还有 "paused"

animation 所有动画属性的简写属性,除了animation-play-state 属性

animation-name animation-duration

<style>
        @keyframes a {
            0% {
                width: 300px;
            }
            50% {
                width: 800px;
            }
            100% {
                width: 300px;
            }
        }
        div {
            animation-name: a;
            animation-duration: 2s;
        }
    </style>
    <script>
    </script>
</head>
<body>
    <div style='background-Color:red;width: 300px;height:300px ;'></div>
</body>

image.gif

image.gif编辑

刷新之后就自动触发动画,执行的动画变量名是a,两秒内完成动画,也就是从0%到100%两秒内完成。

animation-timing-function animation-delay

linear

动画从头到尾的速度是相同的。

ease

默认。动画以低速开始,然后加快,在结束前变慢。

ease-in

动画以低速开始。

ease-out

动画以低速结束。

ease-in-out

动画以低速开始和结束。

cubic-bezier(n,n,n,n)

在 cubic-bezier 函数中自己的值。可能的值是从 0 到 1 的数值

@keyframes a {
            0% {
                width: 300px;
            }
            50% {
                width: 800px;
            }
            100% {
                width: 300px;
            }
        }
        div {
            animation-name: a;
            animation-duration: 5s;
            animation-timing-function: ease-in-out;
            animation-delay: 2s;
        }

image.gif

image.gif编辑

animation-timing-function 动画开始和结束慢速

animation-delay 动画延迟两秒开始。

animation-iteration-count   animation-play-state

@keyframes a {
            0% {
                width: 300px;
            }
            50% {
                width: 800px;
            }
            100% {
                width: 300px;
            }
        }
        div {
            animation-name: a;
            animation-duration: 5s;
            animation-timing-function: ease-in-out;
            animation-delay: 2s;
            animation-iteration-count: infinite;
        }
        div:hover {
            animation-play-state: paused;
        }

image.gif

image.gif编辑

animation-iteration-count  循环次数,infinite重复循环

animation-play-state paused 停止动画  当鼠标移入动画停止

animation-direction  animation-fill-mode

animation-direction

normal 默认值。动画按正常播放。
reverse 动画反向播放。
alternate 动画在奇数次(1、3、5...)正向播放,在偶数次(2、4、6...)反向播放。
alternate-reverse 动画在奇数次(1、3、5...)反向播放,在偶数次(2、4、6...)正向播放。
initial 设置该属性为它的默认值。请参阅 initial
inherit 从父元素继承该属性。请参阅 inherit
@keyframes a {
            0% {
                width: 300px;
            }
            50% {
                width: 500px;
            }
            100% {
                width: 800px;
            }
        }
        div {
            animation-name: a;
            animation-duration: 5s;
            animation-timing-function: ease-in-out;
            animation-delay: 2s;
            animation-iteration-count: infinite;
            /* animation-fill-mode: forwards; */
            animation-direction: alternate;
        }
        div:hover {
            animation-play-state: paused;
        }

image.gif

image.gif编辑

animation-iteration-count:infinite  重复循环  animation-direction:alternate 在偶数次反向播放

就形成了  长度 一直来回变化的效果

animation-fill-mode  

保持 最终状态 forwards 原位置 backwards

image.gif

image.gif编辑

 animation-fill-mode: forwards  宽度到达800后 停止动画 保持在动画执行完毕的状态 不会恢复

animation

直接写出所有的相关动画属性(简写),除了animation-play-state 属性。

animation:动画名称 持续时间 运动曲线 何时开始 播放次数 是否反方向 动画起始或者结束的状态。

 

@keyframes a {
            0% {
                width: 300px;
            }
            50% {
                width: 500px;
            }
            100% {
                width: 800px;
            }
        }
        div {
            animation: a 5s ease-in-out 2s infinite alternate;
        }
        div:hover {
            animation-play-state: paused;
        }

image.gif

image.gif编辑

 

相关文章
|
1月前
|
机器学习/深度学习 前端开发 JavaScript
|
25天前
|
前端开发 搜索推荐 UED
实现 CSS 动画效果的兼容性
【10月更文挑战第16天】实现 CSS 动画效果的兼容性需要对不同浏览器的特性有深入的了解,并采取适当的策略和方法。通过不断的实践和优化,你可以在各种浏览器上创造出流畅、美观且兼容的动画效果,为用户带来更好的体验。在实际开发中,要密切关注浏览器的发展动态,及时掌握最新的兼容性技巧和解决方案,以确保你的动画设计能够在广泛的用户群体中得到良好的呈现。
102 58
|
4天前
|
Web App开发 前端开发 JavaScript
如何在不牺牲动画效果的前提下,优化 CSS3 动画的性能?
如何在不牺牲动画效果的前提下,优化 CSS3 动画的性能?
15 1
|
18天前
|
Web App开发 前端开发 iOS开发
css所有缩写属性,CSS属性简写整理
css所有缩写属性,CSS属性简写整理
16 1
|
30天前
|
前端开发 JavaScript API
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
本文通过构建一个 3D 翻卡动画深入探讨了 CSS Houdini 的强大功能,展示了如何通过 Worklets、自定义属性、Paint API 等扩展 CSS 的能力,实现高度灵活的动画效果。文章首先介绍了 Houdini 的核心概念与 API,并通过构建一个动态星空背景、圆形进度条以及交互式 3D 翻卡动画的实际示例,展示了如何利用 CSS Houdini 赋予网页设计更多创造力。最后,还演示了如何将这种 3D 翻卡效果集成到公司网站中,提升用户体验。CSS Houdini 的创新能力为网页设计带来了前所未有的灵活性,推动了前端开发迈向新的高度。
26 0
探索 CSS Houdini:轻松构建酷炫的 3D 卡片翻转动画
|
1月前
|
前端开发
CSS 中哪些属性可以继承
在 CSS 中,属性分为可继承与不可继承。可继承属性会在子元素中沿用父元素的样式设定。常见可继承属性包括:文本属性(如 `font-family`, `color`),列表属性(如 `list-style`),表格布局属性(如 `border-collapse`),以及其他如 `visibility` 和 `direction` 等属性。正确理解这些属性有助于更高效地进行样式设计。
|
18天前
|
前端开发
css简写属性
css简写属性
24 0
|
1月前
|
前端开发 JavaScript
如何在CSS中添加自定义属性
如何在CSS中添加自定义属性
15 0
|
1月前
|
前端开发
运用CSS伪类与属性,巧妙实现背景图片旋转效果
运用CSS伪类与属性,巧妙实现背景图片旋转效果
27 0
|
1月前
|
前端开发
哪些 CSS 属性可以继承?
哪些 CSS 属性可以继承?
41 0

热门文章

最新文章