欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

CSS3中Animation屬性的使用詳解

WEB前端開發(fā)   發(fā)布時間:2015-08-06 18:26:36   作者:佚名   我要評論
這篇文章主要介紹了CSS3中Animation屬性的使用詳解,是CSS3入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下

在開始介紹Animation之前我們有必要先來了解一個特殊的東西,那就是”Keyframes”,我們把他叫做“關(guān)鍵幀”,玩過flash的朋友可能對這個東西并不會陌生。下面我們就一起來看看這個“Keyframes”是什么東西。前面我們在使用transition制作一個簡單的transition效果時,我們包括了初始屬性和最終屬性,一個開始執(zhí)行動作時間和一個延續(xù)動作時間以及動作的變換速率,其實這些值都是一個中間值,如果我們要控制的更細(xì)一些,比如說我要第一個時間段執(zhí)行什么動作,第二個時間段執(zhí)行什么動作(換到flash中說,就是第一幀我要執(zhí)行什么動作,第二幀我要執(zhí)行什么動作),這樣我們用Transition就很難實現(xiàn)了,此時我們也需要這樣的一個“關(guān)鍵幀”來控制。那么CSS3的Animation就是由“keyframes”這個屬性來實現(xiàn)這樣的效果。下面我們一起先來看看Keyframes:

Keyframes具有其自己的語法規(guī)則,他的命名是由”@keyframes”開頭,后面緊接著是這個“動畫的名稱”加上一對花括號“{}”,括號中就是一些不同時間段樣式規(guī)則,有點像我們css的樣式寫法一樣。對于一個”@keyframes”中的樣式規(guī)則是由多個百分比構(gòu)成的,如“0%”到”100%”之間,我們可以在這個規(guī)則中創(chuàng)建多個百分比,我們分別給每一個百分比中給需要有動畫效果的元素加上不同的屬性,從而讓元素達(dá)到一種在不斷變化的效果,比如說移動,改變元素顏色,位置,大小,形狀等,不過有一點需要注意的是,我們可以使用“fromt”“to”來代表一個動畫是從哪開始,到哪結(jié)束,也就是說這個 “from”就相當(dāng)于”0%”而”to”相當(dāng)于”100%”,值得一說的是,其中”0%”不能像別的屬性取值一樣把百分比符號省略,我們在這里必須加上百分符號(“%”)如果沒有加上的話,我們這個keyframes是無效的,不起任何作用。因為keyframes的單位只接受百分比值。

Keyframes可以指定任何順序排列來決定Animation動畫變化的關(guān)鍵位置。其具體語法規(guī)則如下:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. keyframes-rule: '@keyframes' IDENT '{' keyframes-blocks '}';   
  2.  keyframes-blocks: [ keyframe-selectors block ]* ;   
  3.  keyframe-selectors: [ 'from' | 'to' | PERCENTAGE ] [ ',' [ 'from' | 'to' | PERCENTAGE ] ]*;  

把上面的語法綜合起來

CSS Code復(fù)制內(nèi)容到剪貼板
  1. @keyframes IDENT {   
  2.      from {   
  3.        Properties:Properties value;   
  4.      }   
  5.      Percentage {   
  6.        Properties:Properties value;   
  7.      }   
  8.      to {   
  9.        Properties:Properties value;   
  10.      }   
  11.    }  

   或者全部寫成百分比的形式:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. @keyframes IDENT {   
  2.    0% {   
  3.       Properties:Properties value;   
  4.    }   
  5.    Percentage {   
  6.       Properties:Properties value;   
  7.    }   
  8.    100% {   
  9.       Properties:Properties value;   
  10.    }   
  11.  }  

其中IDENT是一個動畫名稱,你可以隨便取,當(dāng)然語義化一點更好,Percentage是百分比值,我們可以添加許多個這樣的百分比,Properties為css的屬性名,比如說left,background等,value就是相對應(yīng)的屬性的屬性值。值得一提的是,我們from和to 分別對應(yīng)的是0%和100%。這個我們在前面也提到過了。到目前為止支技animation動畫的只有webkit內(nèi)核的瀏覽器,所以我需要在上面的基礎(chǔ)上加上-webkit前綴,據(jù)說Firefox5可以支持css3的 animation動畫屬性。

我們來看一個實例:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. @-webkit-keyframes 'test' {   
  2.      0% {   
  3.         margin-left100px;   
  4.         backgroundgreen;   
  5.      }   
  6.      40% {   
  7.         margin-left150px;   
  8.         background: orange;   
  9.      }   
  10.      60% {   
  11.         margin-left75px;   
  12.         backgroundblue;   
  13.      }   
  14.      100% {   
  15.         margin-left100px;   
  16.         backgroundred;   
  17.      }   
  18.   }  

這里我們定義了一個叫“test”的動畫,他的動畫是從0%開始到100%時結(jié)束,從中還經(jīng)歷了一個40%和60%兩個過程,上面代碼具體意思是:test動畫在0%時元素定位到left為100px的位置背景色為green,然后40%時元素過渡到left為150px的位置并且背景色為orange,60%時元素過渡到left為75px的位置,背景色為blue,最后100%結(jié)束動畫的位置元素又回到起點left為100px處,背景色變成red。假設(shè)置我們只給這個動畫有10s的執(zhí)行時間,那么他每一段執(zhí)行的狀態(tài)如下圖所示:
201586182405067.png (499×536)

Keyframes定義好了以后,我們需要怎么去調(diào)用剛才定義好的動畫“test”

CSS3的animation類似于transition屬性,他們都是隨著時間改變元素的屬性值。他們主要區(qū)別是transition需要觸發(fā)一個事件(hover事件或click事件等)才會隨時間改變其css屬性;而animation在不需要觸發(fā)任何事件的情況下也可以顯式的隨著時間變化來改變元素css的屬性值,從而達(dá)到一種動畫的效果。這樣我們就可以直接在一個元素中調(diào)用animation的動畫屬性,基于這一點,css3的animation就需要明確的動畫屬性值,這也就是回到我們上面所說的,我們需要keyframes來定義不同時間的css屬性值,達(dá)到元素在不同時間段變化的效果。

下面我們來看看怎么給一個元素調(diào)用animation屬性

CSS Code復(fù)制內(nèi)容到剪貼板
  1. .demo1 {   
  2.      width50px;   
  3.      height50px;   
  4.      margin-left100px;   
  5.      backgroundblue;   
  6.      -webkit-animation-name:'wobble';/*動畫屬性名,也就是我們前面keyframes定義的動畫名*/  
  7.      -webkit-animation-duration: 10s;/*動畫持續(xù)時間*/  
  8.      -webkit-animation-timing-function: ease-in-out; /*動畫頻率,和transition-timing-function是一樣的*/  
  9.      -webkit-animation-delay: 2s;/*動畫延遲時間*/  
  10.      -webkit-animation-iteration-count: 10;/*定義循環(huán)資料,infinite為無限次*/  
  11.      -webkit-animation-direction: alternate;/*定義動畫方式*/  
  12.   }  

CSS Animation動畫效果將會影響元素相對應(yīng)的css值,在整個動畫過程中,元素的變化屬性值完全是由animation來控制,動畫后面的會覆蓋前面的屬性值。如上面例子:因為我們這個demo只是在不同的時間段改變了demo1的背景色和左邊距,其默認(rèn)值是:margin-left:100px;background: blue;但當(dāng)我們在執(zhí)行動畫0%時,margin-left:100px,background:green;當(dāng)執(zhí)行到40%時,屬性變成了:margin-left:150px;background:orange;當(dāng)執(zhí)行到60%時margin-left:75px;background:blue;當(dāng)動畫 執(zhí)行到100%時:margin-left:100px;background: red;此時動畫將完成,那么margin-left和background兩個屬性值將是以100%時的為主,他不會產(chǎn)生疊加效果,只是一次一次覆蓋前一次出將的css屬性。就如我們平時的css一樣,最后出現(xiàn)的權(quán)根是最大的。當(dāng)動畫結(jié)束后,樣式回到默認(rèn)效果。

相關(guān)文章

最新評論