CSS3 animation-fill-mode 属性

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CSS3 animation-fill-mode 属性相关的知识,希望对你有一定的参考价值。

现在专注于移动端开发项目,对于动画这个点是非常重要的,每当我遇到一个新的知识点,我就会和大家一起分享

animation-fill-mode :把物体动画地从一个地方移动到另一个地方,并让它停留在那里

定义和用法

animation-fill-mode 属性规定当动画不播放时(当动画完成时,或当动画有一个延迟未开始播放时),要应用到元素的样式。

默认情况下,CSS 动画在第一个关键帧播放完之前不会影响元素,在最后一个关键帧完成后停止影响元素。animation-fill-mode 属性可重写该行为。

默认值: none
继承:
可动画化: 否。
版本: CSS3
javascript 语法: object.style.animationFillMode="forwards"

特别是对于JS控制这一块,还可以将其恢复到最后一个关键帧完成后停止影响的状态

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        div{
            width: 100px;
            height: 100px;
            background: red;
            position: relative;
            animation:move 2s linear;
        }
        @keyframes move {
            from{
                left:0;}
            to{
                left:100px;
            }
        }

    </style>
</head>
<body>
     <div id="div"></div>
     <button>试一试</button>
     <script>
         window.onload = function(){
             var div = document.getElementById("div")
             var btn = document.getElementsByTagName("button")[0]
             btn.onclick = function(){
                 div.style.animationFillMode = "forwards"
             }
                         //把动画状态恢复到最后一帧的状态
         }
     </script>
</body>
</html>

 

以上是关于CSS3 animation-fill-mode 属性的主要内容,如果未能解决你的问题,请参考以下文章

CSS3animation动画为啥会出现抖动效果,怎么解决

CSS3 动画填充模式 polyfill

css3动画特效:上下晃动的div

css3 forwardsbackwardsboth

CSS3 关键帧动画:结束并停留在最后一帧

css3动画如何在动作结束时保持该状态不变