纯CSS方式实现CSS动画的暂停与播放!

使用纯 CSS 的方法,能否暂停、播放 CSS 动画?看起来不可能,至少很麻烦。

我们知道,在 CSS3 animation 中,有这样一个属性可以暂停、播放动画:

 
 
 
 
  1.  
  2.     animation-play-state: paused | running; 
  3.  

 

animation-play-state: 属性定义一个动画是否运行或者暂停。可以通过查询它来确定动画是否正在运行。另外,它的值可以被设置为暂停和恢复的动画的重放。

如果借助 Javascript,我们可以实现控制 CSS 动画的运行和播放,下面列出部分关键代码:

 
 
 
 
  1. stop
 
  •  
  •  
  •  
  •  
  •  

     
     
     
     
    1. document.querySelector('.btn').addEventListener('click', function() { 
    2.  
    3.     let btn = document.querySelector('.btn'); 
    4.  
    5.     let elem = document.querySelector('.animation'); 
    6.  
    7.     let state = elem.style['animationPlayState']; 
    8.  
    9.      
    10.  
    11.     if(state === 'paused') { 
    12.  
    13.         elem.style['animationPlayState'] = 'running'; 
    14.  
    15.         btn.innerText = 'stop'; 
    16.  
    17.     } else { 
    18.  
    19.         elem.style['animationPlayState'] = 'paused'; 
    20.  
    21.         btn.innerText = 'play'; 
    22.  
    23.     } 
    24.  
    25.      
    26.  
    27. }); 

     

    Demo — pause CSS Animation(https://codepen.io/Chokcoco/pen/GWYBdM)

    纯 CSS 实现

    下面我们探讨下,使用纯 CSS 的方式能否实现。

    hover 伪类实现

    使用 hover 伪类,在鼠标悬停在按钮上面时,控制动画样式的暂停。

    关键代码如下:

     
     
     
     
    1. stop
     
  •  
  •  
  •  
  •  
  •  

    Demo — 纯 CSS 方式实现 CSS 动画的暂停与播放 (Hover):(https://codepen.io/Chokcoco/pen/PpxKBX)

    当然,这个方法不够智能,如果释放鼠标的自由,点击一下暂停、再点击一下播放就好了。还有其他方法吗?

    checked 伪类实现

    之前的文章《有趣的 CSS 题目(8):纯CSS的导航栏Tab切换方案》也谈过,使用 radio 标签的 checked 伪类,加上 实现纯 CSS 捕获点击事情。

    并且利用被点击的元素可以控制一些 CSS 样式。实现如下:

     
     
     
     
    1.  
    2.  
    3.  
    4.  
    5.  
    6.  
    7.      
    8.  
    9.         stop 
    10.  
    11.      
    12.  
    13.      
    14.  
    15.         play 
    16.  
    17.      
    18.  
    19.  
    20.  
    21.  

     

    部分关键 CSS 代码:

     
     
     
     
    1. .animation { 
    2.  
    3.     animation: move 2s linear infinite alternate; 
    4.  
    5.  
    6.   
    7.  
    8. #stop:checked ~ .animation { 
    9.  
    10.     animation-play-state: paused; 
    11.  
    12.  
    13.   
    14.  
    15. #play:checked ~ .animation { 
    16.  
    17.     animation-play-state: running; 
    18.  

     

    我们希望当 #stop 和 #play 两个 radio 被点击时,给 .animation 元素分别赋予 animation-play-state: paused 或是 animation-play-state: running 。而且二者只能生效其一,所以需要给两个 radio 标签赋予相同的 name 属性。

    DEMO — 纯 CSS 方式实现 CSS 动画的暂停与播放:(https://codepen.io/Chokcoco/pen/QpJwBW)

    上面的示例 Demo 中,实现了纯 CSS 方式实现 CSS 动画的暂停与播放。

    当然,还有一些其他方法,例如 radio 替换成 checkbox ,或者使用 :target 伪类选择器也能实现上面同样的效果,感兴趣的可以尝试一下。

    到此本文结束,如果还有什么疑问或者建议,可以多多交流,原创文章,文笔有限,才疏学浅,文中若有不正之处,万望告知。

    开本系列,谈谈一些有趣的 CSS 题目,题目类型天马行空,想到什么说什么,不仅为了拓宽一下解决问题的思路,更涉及一些容易忽视的 CSS 细节。

    解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题中有你感觉到生僻的 CSS 属性,赶紧去补习一下吧。

    不断更新,不断更新,不断更新,重要的事情说三遍。

    当前题目:纯CSS方式实现CSS动画的暂停与播放!
    本文链接:http://www.csdahua.cn/qtweb/news5/346605.html

    网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

    广告

    声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网

    成都快上网为您推荐相关内容

    网站策划知识

    行业网站建设