亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

純CSS3實(shí)現(xiàn)給頭像加個(gè)光芒四射且旋轉(zhuǎn)的背景動(dòng)畫效果

  發(fā)布時(shí)間:2014-05-07 13:32:04   作者:佚名   我要評(píng)論
之前我用JavaScript和CSS3制作出了相同的效果,本文里我是想改進(jìn)一下之前的技術(shù),我想讓它變的更容易,我想去掉js代碼,只用CSS3來(lái)實(shí)現(xiàn)整個(gè)效果

HTML代碼

HTML代碼結(jié)構(gòu)很簡(jiǎn)單,跟之前那篇文章使用的相同:

復(fù)制代碼
代碼如下:

<div id="raysDemoHolder">
<a href="/" id="raysLogo">WebHek</a>
<div id="rays"></div>
</div>

最外面的div作為父元素,它的position是relative,有固定的高和寬度,有兩個(gè)子元素:一個(gè)用來(lái)放logo,一個(gè)用來(lái)做光芒效果的容器。

CSS代碼

我們這里要用純CSS來(lái)實(shí)現(xiàn),需要使用CSS3的動(dòng)畫技術(shù),這里用到的CSS語(yǔ)法是@keyframes。我們的基本實(shí)現(xiàn)原理是用keyframes,從rotate(0deg)旋轉(zhuǎn)到rotate(360deg):

復(fù)制代碼
代碼如下:

/* 用來(lái)實(shí)現(xiàn)動(dòng)畫的keyframes; 從0度旋轉(zhuǎn)到360度 */
@keyframes spin {
from { transform: rotate(0deg); }
to { transform: rotate(360deg); }
}
/* 實(shí)現(xiàn)光線輻射效果 */
#raysDemoHolder {
position: relative;
width: 490px;
height: 490px;
margin: 100px 0 0 200px;
}
#raysLogo {
width: 300px;
height: 233px;
text-indent: -3000px;
background: url(logo.png) 0 0 no-repeat;
display: block;
position: absolute;
top: 0;
left: 0;
z-index: 2;
}
#rays { /* 表現(xiàn)動(dòng)畫效果 */
background: url(rays.png) 0 0 no-repeat;
position: absolute;
top: -100px;
left: -100px;
width: 490px;
height: 490px; </p> <p> /* microsoft ie */
animation-name: spin;
animation-duration: 40000ms; /* 40 seconds */
animation-iteration-count: infinite;
animation-timing-function: linear;
}
#rays:hover {
/* animation-duration: 10000ms;*/
/* 10 seconds - speed it up on hover! */
/* resets the position though! sucks */
}

通過(guò)使用animation-timing-function, animation-duration, 和 animation-iteration-count,我們就能實(shí)現(xiàn)線性勻速、旋轉(zhuǎn)不停的動(dòng)畫效果!你會(huì)發(fā)現(xiàn)使用純CSS制作的動(dòng)畫比用js制作的動(dòng)畫要順滑的多。

現(xiàn)在我們有了一個(gè)問(wèn)題,早期的Opera瀏覽器不支持@keyframes語(yǔ)法。幸運(yùn)的是,我們可以通過(guò)其它方法實(shí)現(xiàn)這個(gè)動(dòng)畫:

復(fù)制代碼
代碼如下:

/* boooo opera */
-o-transition: rotate(3600deg); /* 可用 */

只需要簡(jiǎn)單的一段代碼。而對(duì)于IE瀏覽器,我試圖用-ms-transform / -ms-translation在IE9里運(yùn)行它,但不好用。從IE10才開(kāi)始支持keyframes語(yǔ)法。

不斷的改進(jìn)自己之前的代碼是個(gè)好習(xí)慣。雖然這個(gè)純CSS實(shí)現(xiàn)的動(dòng)畫并不能在IE9里正確的運(yùn)行,但I(xiàn)E10+,火狐,谷歌瀏覽器里都工作的非常好。如果必須要支持IE9,你仍然可以使用CSS條件判斷語(yǔ)法和JavaScript配合實(shí)現(xiàn)js版的效果。

相關(guān)文章

最新評(píng)論