问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

css animation 怎么兼容ie火狐呢

发布网友 发布时间:2022-04-22 00:33

我来回答

3个回答

懂视网 时间:2022-04-22 04:54

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

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

好久没更新blog,上次发文(11月8日)到现在刚好一个月,期间项目上的东西比较多,一时觉得时间比较紧,没来得及更新。这个星期总算是告一段落,补上几篇技术性的文章。好吧,第一篇是关于css3动画的使用。
昨天突然看到jing.fm(这个音乐网站非常不错,很多效果我都很喜欢,如果你有兴趣,可以去围观下)上音乐播放时,专辑的转动效果很不错,所以准备自己动手写下,以备后用。结果第一次使用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> 
<p id="bd"> 
<p id="musicBox"> 
<p class="cover rotateCD"></p> 
<p class="mask"></p> 
</p> 
</p> 
</body> 
</html>

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

热心网友 时间:2022-04-22 02:02

animation 是CSS3 里的。就不兼容。 IE 10+  ,chrome , FF 5+ 才可以看到效果。

如果想兼容。可以用js 或是jq 等实现。

热心网友 时间:2022-04-22 03:20

暂时无解,可以使用js代替。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
...辞职后住房公积金怎么办啊,现在人不在外地,钱能取出来吗?还是可以转... 公积金辞职了能否取出来 拼多多一单拍两个地址(拼多多一单两个地址,如何处理) 冷却塔噪音隔音 监理工程师培训班哪家好 大立教育和学天教育二消培训哪个好 ...有的话分数线大概多少?如果是考进去的话大概需要多少分。 2011武职空务乘员单招已过,录取通知书何时下来 石家庄育才路168号到火车站打的多少钱 dell电脑散热是按哪个键 小狗R55 Pro扫地机器人好用不好用呢?听说是新上市的 历史周期律谈话是什么 小狗扫地机器人前面的两个小刷子不转 韩愈《马说》中写只有千里马,而没有识马的人的句子是? 历史周期律形成的根源是什么 知乎 小狗智能扫地机器人维修点,是哪里啊? 问一下大家小狗扫地机器人如何,好用不?具体大家觉得怎么样。 《千里马》原文 黄炎培的历史周期律指的是什么 小狗智能扫地机器人V-M900R质量如何?谁用过呀介绍一下,买这个行吗? 答:什么是历史周期律 黄炎培的历史周期律是什么? 问一下小狗智能扫地机器人咋样,好用不?有用过的没,朋友说是不错。? 问一下小狗扫地机器人如何呢,听说除尘效果特别好。详细情况谁了解。 为什么微博上关注好友,怎么输入昵称都收不到呢, 小狗吸尘器滤芯怎么拆 一体机智能马桶smartcleaner,以前有电没电手动都正常,现在没电手动不出水了 心海伽蓝智能马桶不冲水 智能坐便器妇洗不出水。怎么办呢 老式康佳电视宽带能播放名校课堂吗? 韩愈强调千里马与常马不同,主张按照千里马的特性来对待它,你同意吗?为什么? 韩愈多次提到&quot;千里马&quot;的方式有哪几种?各具有怎样的效果 发光体都是什么 想想看,韩愈为什么用千里马而不用别的动物来比喻杰出的人才 发光体的介绍 诗人韩愈为何说道:世有伯乐,然后有千里马? “光源”与“发光体&#39;的区别? 韩愈是主张怎样对待千里马那样的人才的 《发光体(2020)》百度网盘免费在线观看,伊娃·格林主演的 发光体的歌词 夜空中看到的星星都是和太阳一样是个发光体吗? 发光体就叫光对吗? 古人形容“千里马”的句子有哪些? 发光体和光源是一回事吗? 韩愈在《马说》中认为&quot;世有伯乐,然后有千里马&quot;,请就此观点发表自己的看法 韩愈说“世有伯乐,那后有千里马”实际含义是什么 何洁的《发光体》 歌词 发光体所发出的光线的颜色称作什么? 古代有关千里马的传说很多,韩愈写马说的目的是 。本文借“涓人”买 ... 绿色的发光体是什么东西?