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


Posted in HTML / CSS onJanuary 09, 2013

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

复制代码
代码如下:

<!DOCTYPE html>
<html>
<head>
<meta charset='utf-8'>
<title>音乐专辑播放模拟</title>
<link rel="stylesheet" type="text/css" href="css/style.css">
</head>
<body>
<div id="bd">
<div id="musicBox">
<div class="cover rotateCD"></div>
<div class="mask"></div>
</div>
</div>
</body>
</html>

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

css3强大的动画效果animate使用说明及浏览器兼容介绍
三、css3样式表

复制代码
代码如下:

@charset utf-8;
/* common: rotateCD */
@-webkit-keyframes myrotate{
0%{
-webkit-transform : rotate(0deg);
}
100%{
-webkit-transform : rotate(360deg);
}
}
@-moz-keyframes myrotate{
0%{
-moz-transform : rotate(0deg);
}
100%{
-moz-transform : rotate(360deg);
}
}
@-ms-keyframes myrotate{
0%{
-ms-transform : rotate(0deg);
}
100%{
-ms-transform : rotate(360deg);
}
}
@-o-keyframes myrotate{
0%{
-o-transform : rotate(0deg);
}
100%{
-o-transform : rotate(360deg);
}
}
@keyframes myrotate{
0%{
transform : rotate(0deg);
}
100%{
transform : rotate(360deg);
}
}
.rotateCD{
-webkit-animation: myrotate 9.5s infinite linear;
-moz-animation: myrotate 9.5s infinite linear;
-ms-animation: myrotate 9.5s infinite linear;
-o-animation: myrotate 9.5s infinite linear;
animation: myrotate 9.5s infinite linear;
-webkit-animation-play-state: running;
-moz-animation-play-state: running;
-ms-animation-play-state: running;
-o-animation-play-state: running;
animation-play-state: running;
}
/* module: bd */
#bd{width: 960px;margin: 200px auto 0;}
/* module: musicBox */
#musicBox{position: relative;width: 430px;height: 430px;margin: 0 auto;overflow: hidden;}
#musicBox .cover{width: 300px;height: 300px;margin: 65px;background: url(../img/music1.jpg) 0 0 no-repeat;}
#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设置写成了,如下面的代码所示:
复制代码
代码如下:

@-webkit-keyframes myrotate{
0%{
-webkit-transform : rotate(0deg);
-moz-transform : rotate(0deg);
-ms-transform : rotate(0deg);
-o-transform : rotate(0deg);
transform : rotate(0deg);
}
....

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

@-webkit-keyframes myrotate{
0%{
-webkit-transform : rotate(0deg);
}
...
@-moz-keyframes myrotate{
0%{
-moz-transform : rotate(0deg);
}
...
@-ms-keyframes myrotate{
0%{
-ms-transform : rotate(0deg);
}
...
@-o-keyframes myrotate{
0%{
-o-transform : rotate(0deg);
}
...
@keyframes myrotate{
0%{
transform : rotate(0deg);
}
...

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)。
HTML / CSS 相关文章推荐
一款基于css3的动画按钮代码教程
Nov 23 HTML / CSS
css3学习系列之移动属性详解
Jul 04 HTML / CSS
socket.io 和canvas 实现的共享画板功能
May 22 HTML / CSS
HTML5 Canvas中使用路径描画二阶、三阶贝塞尔曲线
Jan 01 HTML / CSS
基于HTML5+CSS3实现简单的时钟效果
Sep 11 HTML / CSS
微信html5页面调用第三方位置导航的示例
Mar 14 HTML / CSS
canvas实现扭蛋机动画效果的示例代码
Oct 17 HTML / CSS
详解HTML5 Canvas标签及基本使用
Jan 10 HTML / CSS
浅析HTML5 Landmark
Sep 11 HTML / CSS
前端使用canvas生成盲水印的加密解密的实现
Dec 16 HTML / CSS
HTML怎么设置下划线?html文字加下划线方法
Dec 06 HTML / CSS
HTML5之高度塌陷问题的解决
Jun 01 HTML / CSS
css3 box-sizing属性使用参考指南
Jan 08 #HTML / CSS
css3背景图片透明叠加属性cross-fade简介及用法实例
Jan 08 #HTML / CSS
纯CSS3编写的的精美动画进度条(无flash/无图像/无脚本/附源码)
Jan 07 #HTML / CSS
CSS3 icon font完全指南(CSS3 font 会取代icon图标)
Jan 06 #HTML / CSS
css3 旋转按钮 使用CSS3创建一个旋转可变色按钮
Dec 31 #HTML / CSS
绝对令人的惊叹的CSS3折叠效果(3D效果)整理
Dec 30 #HTML / CSS
纯CSS打造(无图像无js)的非常流行的讲话(语音)气泡效果
Dec 28 #HTML / CSS
You might like
thinkphp文件引用与分支结构用法实例
2014/11/26 PHP
php结合正则获取字符串中数字
2015/06/19 PHP
Yii2如何批量添加数据
2016/05/17 PHP
thinkPHP框架可添加js事件的分页类customPage.class.php完整实例
2017/03/16 PHP
thinkPHP5框架导出Excel文件简单操作示例
2018/08/03 PHP
基于jQuery实现下拉收缩(展开与折叠)特效
2012/12/25 Javascript
JS实现很酷的EMAIL地址添加功能实例
2015/02/28 Javascript
javascript常用函数(2)
2015/11/05 Javascript
AngularJS实现元素显示和隐藏的几个案例
2015/12/09 Javascript
鼠标点击input,显示瞬间的边框颜色,对之修改与隐藏实例
2016/12/26 Javascript
浅谈js中同名函数和同名变量的执行问题
2017/02/12 Javascript
bootstrap suggest搜索建议插件使用详解
2017/03/25 Javascript
关于vue中的ajax请求和axios包问题
2018/04/19 Javascript
vue 地图可视化 maptalks 篇实例代码详解
2019/05/21 Javascript
使用Vue开发自己的Chrome扩展程序过程详解
2019/06/21 Javascript
JavaScript Window窗口对象属性和使用方法
2020/01/19 Javascript
原生JS与JQ获取元素的区别详解
2020/02/13 Javascript
[36:19]2018DOTA2亚洲邀请赛 小组赛 A组加赛 Newbee vs LGD
2018/04/03 DOTA
[50:24]VGJ.S vs Pain 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/20 DOTA
python 拷贝特定后缀名文件,并保留原始目录结构的实例
2018/04/27 Python
两种CSS3伪类选择器详细介绍
2013/12/24 HTML / CSS
CSS3.0实现霓虹灯按钮动画特效的示例代码
2021/01/12 HTML / CSS
基于 HTML5 WebGL 实现的医疗物流系统
2019/10/08 HTML / CSS
施华洛世奇德国官网:SWAROVSKI德国
2017/02/01 全球购物
戴尔英国官网:Dell英国
2017/05/27 全球购物
捷克浴室和厨房设备购物网站:SIKO
2018/08/11 全球购物
瑞典耳机品牌:URBANISTA
2019/12/03 全球购物
Harman Audio官方商店:购买JBL、Harman Kardon、Infinity和AKG
2019/12/05 全球购物
岗位聘任书范文
2014/03/29 职场文书
共产党员岗位承诺书
2014/05/29 职场文书
优秀教师推荐材料
2014/12/16 职场文书
学校元旦晚会开场白
2015/05/29 职场文书
初中班级口号霸气押韵
2015/12/24 职场文书
《秋天的雨》教学反思
2016/02/19 职场文书
pytorch MSELoss计算平均的实现方法
2021/05/12 Python
多线程Spring通过@Scheduled实现定时任务
2022/05/25 Java/Android