当前位置:Gxlcms > css > 关于css3的动画效果animate的使用说明及浏览器兼容的介绍

关于css3的动画效果animate的使用说明及浏览器兼容的介绍

时间:2021-07-01 10:21:17 帮助过:11人阅读

这篇文章主要介绍了关于css3的动画效果animate的使用说明及浏览器兼容的介绍,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

昨天突然看到jing.fm(这个音乐网站非常不错,很多效果我都很喜欢,如果你有兴趣,可以去围观下)上音乐播放时,专辑的转动效果很不错,所以准备自己动手写下,以备后用。结果第一次使用animate就遇到了坑爹的事情,特吐槽下

好久没更新blog,上次发文(11月8日)到现在刚好一个月,期间项目上的东西比较多,一时觉得时间比较紧,没来得及更新。这个星期总算是告一段落,补上几篇技术性的文章。好吧,第一篇是关于css3动画的使用。
昨天突然看到jing.fm(这个音乐网站非常不错,很多效果我都很喜欢,如果你有兴趣,可以去围观下)上音乐播放时,专辑的转动效果很不错,所以准备自己动手写下,以备后用。结果第一次使用animate就遇到了坑爹的事情,特吐槽下。
一、最终的效果

如上图所示,最终是想让这个专辑的图片转动起来,模拟出唱片播放的效果(你可以去jing.fm上看看真实的效果,很赞,现在很多音乐网站都添加了这个效果)。
二、结构代码

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset='utf-8'>
  5. <title>音乐专辑播放模拟</title>
  6. <link rel="stylesheet" type="text/css" href="css/style.css">
  7. </head>
  8. <body>
  9. <p id="bd">
  10. <p id="musicBox">
  11. <p class="cover rotateCD"></p>
  12. <p class="mask"></p>
  13. </p>
  14. </p>
  15. </body>
  16. </html>

从上面的代码可以看出,由于是使用css3强大的动画效果,所以我的结构定义的非常简单(在符合语义的前提下),同时没有引用到javascript脚本文件。
musicBox来限定外围框的大小,内部的cover用来显示专辑封面图片,这个图片是下图左边图片这样的,四四方方,不是圆形,所以我在后面做了个mask的p,它不做其他事情,只是用来容纳一个遮罩(下图右边图片),盖住图片圆形之外的部分。
    
三、css3样式表

  1. @charset utf-8;
  2. /* common: rotateCD */
  3. @-webkit-keyframes myrotate{
  4. 0%{
  5. -webkit-transform : rotate(0deg);
  6. }
  7. 100%{
  8. -webkit-transform : rotate(360deg);
  9. }
  10. }
  11. @-moz-keyframes myrotate{
  12. 0%{
  13. -moz-transform : rotate(0deg);
  14. }
  15. 100%{
  16. -moz-transform : rotate(360deg);
  17. }
  18. }
  19. @-ms-keyframes myrotate{
  20. 0%{
  21. -ms-transform : rotate(0deg);
  22. }
  23. 100%{
  24. -ms-transform : rotate(360deg);
  25. }
  26. }
  27. @-o-keyframes myrotate{
  28. 0%{
  29. -o-transform : rotate(0deg);
  30. }
  31. 100%{
  32. -o-transform : rotate(360deg);
  33. }
  34. }
  35. @keyframes myrotate{
  36. 0%{
  37. transform : rotate(0deg);
  38. }
  39. 100%{
  40. transform : rotate(360deg);
  41. }
  42. }
  43. .rotateCD{
  44. -webkit-animation: myrotate 9.5s infinite linear;
  45. -moz-animation: myrotate 9.5s infinite linear;
  46. -ms-animation: myrotate 9.5s infinite linear;
  47. -o-animation: myrotate 9.5s infinite linear;
  48. animation: myrotate 9.5s infinite linear;
  49. -webkit-animation-play-state: running;
  50. -moz-animation-play-state: running;
  51. -ms-animation-play-state: running;
  52. -o-animation-play-state: running;
  53. animation-play-state: running;
  54. }
  55. /* module: bd */
  56. #bd{width: 960px;margin: 200px auto 0;}
  57. /* module: musicBox */
  58. #musicBox{position: relative;width: 430px;height: 430px;margin: 0 auto;overflow: hidden;}
  59. #musicBox .cover{width: 300px;height: 300px;margin: 65px;background: url(../img/music1.jpg) 0 0 no-repeat;}
  60. #musicBox .mask{position: absolute;top: 0;left: 0;width: 100%;height: 100%;background: url(../img/playerMask.png) 0 0 no-repeat;}

rotateCD这部分的代码兼容了多种高级浏览器(当然是支持css3的),设置了动画执行的时间和其他一些设置,你可以查询animate的更多知识来深入了解。
对于上面的关于动画关键帧keyframes的写法,踩了比较多的坑,一开始,我是看《HTML5与CSS3权威指南》上的例子,它只写了chrome下的写法(比较坑爹,我猜测估计是作者认为其他浏览器的写法与此类似,所以让读者自己去摸索),我想当然的把其他浏览器的兼容性rotate设置写成了,如下面的代码所示:

  1. @-webkit-keyframes myrotate{
  2. 0%{
  3. -webkit-transform : rotate(0deg);
  4. -moz-transform : rotate(0deg);
  5. -ms-transform : rotate(0deg);
  6. -o-transform : rotate(0deg);
  7. transform : rotate(0deg);
  8. }
  9. ....

这样导致的结果就是,chrome和safari下动画正常,FF、opera和IE下均无动画。其实这部分很好理解,myrotate的关键帧只是对webkit做了特殊说明,其他浏览器根本对此置之不理,所以没有动画的效果。
因此,我们在写关键帧适配样式的时候,一定要写成下面的形式:

  1. @-webkit-keyframes myrotate{
  2. 0%{
  3. -webkit-transform : rotate(0deg);
  4. }
  5. ...
  6. @-moz-keyframes myrotate{
  7. 0%{
  8. -moz-transform : rotate(0deg);
  9. }
  10. ...
  11. @-ms-keyframes myrotate{
  12. 0%{
  13. -ms-transform : rotate(0deg);
  14. }
  15. ...
  16. @-o-keyframes myrotate{
  17. 0%{
  18. -o-transform : rotate(0deg);
  19. }
  20. ...
  21. @keyframes myrotate{
  22. 0%{
  23. transform : rotate(0deg);
  24. }
  25. ...

opera浏览器还有个比较怪异的地方,它偏爱@keyframes myrotate{...},而对@-o-keyframes myrotate{...}不感冒,所以你发现两者只存其一的时候,前者可以实现动画,而后者不能实现动画效果。我一直对此很是不解,后来找到关于opera的介绍,说它是严格的执行W3C网页标准。这样想想,就明白了为什么它如此偏爱@keyframes myrotate{...}了。
四、总结
css3看起来非常美好,但是实际使用中还是存在不少的不确定性。如果不能看到已经实现的代码模板,你很难确信自己的代码格式就一定正确。所以你可以到一些不错的网站来观察各种动画效果,选择自己喜欢的动画并生成代码,下载下来后再按照自己的需求来编写动画代码。这样会让你的动画效果实现起来事半功倍(不要担心它达不到你的要求,上面有很多的效果,你可以自己组合,只要你的想象力够丰富)。
好吧,本文到此结束。
PS:文中使用到的浏览器为chrome(21.0.1180.15)、safari5.1.7(7534.57.2)、opera(12.11)、FF(17.0.1)和IE10(10.0.9200.16438)。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

CSS中使用Flexbox来达到居中效果的方法实现

如何使用css3实现input输入框颜色渐变发光的效果

以上就是关于css3的动画效果animate的使用说明及浏览器兼容的介绍的详细内容,更多请关注Gxl网其它相关文章!

人气教程排行