W3C標準中對css3的transition這是樣描述的:「css的transition容許css的屬性值在必定的時間區間內平滑地過渡。這種效果能夠在鼠標單擊、得到焦點、被點擊或對元素任何改變中觸發,並圓滑地以動畫效果改變CSS的屬性值。」javascript
下面咱們一樣從其最語法和屬性值開始一步一步來學習transition的具體使用css
語法:java
transition主要包含四個屬性值:執行變換的屬性:transition-property,變換延續的時間:transition-duration,在延續時間段,變換的速率變化transition-timing-function,變換延遲時間transition-delay。下面分別來看這四個屬性值css3
1、transition-property:web
語法:瀏覽器
transition-property是用來指定當元素其中一個屬性改變時執行transition效果,其主要有如下幾個值:none(沒有屬性改變);all(全部屬性改變)這個也是其默認值;indent(元素屬性名)。當其值爲none時,transition立刻中止執行,當指定爲all時,則元素產生任何屬性值變化時都將執行transition效果,ident是能夠指定元素的某一個屬性值。其對應的類型以下:ruby
一、color: 經過紅、綠、藍和透明度組件變換(每一個數值處理)如:background-color,border-color,color,outline-color等css屬性;ide
二、length: 真實的數字 如:word-spacing,width,vertical-align,top,right,bottom,left,padding,outline-width,margin,min-width,min-height,max-width,max-height,line-height,height,border-width,border-spacing,background-position等屬性;函數
三、percentage:真實的數字 如:word-spacing,width,vertical-align,top,right,bottom,left,min-width,min-height,max-width,max-height,line-height,height,background-position等屬性;學習
四、integer離散步驟(整個數字),在真實的數字空間,以及使用floor()轉換爲整數時發生 如:outline-offset,z-index等屬性;
五、number真實的(浮點型)數值,如:zoom,opacity,font-weight,等屬性;
六、transform list:詳情請參閱:《CSS3 Transform》
七、rectangle:經過x, y, width 和 height(轉爲數值)變換,如:crop
八、visibility: 離散步驟,在0到1數字範圍以內,0表示「隱藏」,1表示徹底「顯示」,如:visibility
九、shadow: 做用於color, x, y 和 blur(模糊)屬性,如:text-shadow
十、gradient: 經過每次中止時的位置和顏色進行變化。它們必須有相同的類型(放射狀的或是線性的)和相同的中止數值以便執行動畫,如:background-image
十一、paint server (SVG): 只支持下面的狀況:從gradient到gradient以及color到color,而後工做與上面相似
十二、space-separated list of above:若是列表有相同的項目數值,則列表每一項按照上面的規則進行變化,不然無變化
1三、a shorthand property: 若是縮寫的全部部分均可以實現動畫,則會像全部單個屬性變化同樣變化
具體什麼css屬性能夠實現transition效果,在W3C官網中列出了全部能夠實現transition效果的CSS屬性值以及值的類型,你們能夠點這裏瞭解詳情。這裏須要提醒一點是,並非什麼屬性改變都爲觸發transition動做效果,好比頁面的自適應寬度,當瀏覽器改變寬度時,並不會觸發transition的效果。但上述表格所示的屬性類型改變都會觸發一個transition動做效果。
2、transition-duration:
語法:
transition-duration是用來指定元素 轉換過程的持續時間,取值:<time>爲數值,單位爲s(秒)或者ms(毫秒),能夠做用於全部元素,包括:before和:after僞元素。其默認值是0,也就是變換時是即時的。
3、transition-timing-function:
語法:
取值:
transition-timing-function的值容許你根據時間的推動去改變屬性值的變換速率,transition-timing-function有6個可能值:
一、ease:(逐漸變慢)默認值,ease函數等同於貝塞爾曲線(0.25, 0.1, 0.25, 1.0).
二、linear:(勻速),linear 函數等同於貝塞爾曲線(0.0, 0.0, 1.0, 1.0).
三、ease-in:(加速),ease-in 函數等同於貝塞爾曲線(0.42, 0, 1.0, 1.0).
四、ease-out:(減速),ease-out 函數等同於貝塞爾曲線(0, 0, 0.58, 1.0).
五、ease-in-out:(加速而後減速),ease-in-out 函數等同於貝塞爾曲線(0.42, 0, 0.58, 1.0)
六、cubic-bezier:(該值容許你去自定義一個時間曲線), 特定的cubic-bezier曲線。 (x1, y1, x2, y2)四個值特定於曲線上點P1和點P2。全部值需在[0, 1]區域內,不然無效。
其是cubic-bezier爲經過貝賽爾曲線來計算「轉換」過程當中的屬性值,以下曲線所示,經過改變P1(x1, y1)和P2(x2, y2)的座標能夠改變整個過程的Output Percentage。初始默認值爲default.
其餘幾個屬性的示意圖:
4、transition-delay:
語法:
transition-delay是用來指定一個動畫開始執行的時間,也就是說當改變元素屬性值後多長時間開始執行transition效果,其取值:<time>爲數值,單位爲s(秒)或者ms(毫秒),其使用和transition-duration極其類似,也能夠做用於全部元素,包括:before和:after僞元素。 默認大小是"0",也就是變換當即執行,沒有延遲。
有時咱們不僅改變一個css效果的屬性,而是想改變兩個或者多個css屬性的transition效果,那麼咱們只要把幾個transition的聲明串在一塊兒,用逗號(「,」)隔開,而後各自能夠有各自不一樣的延續時間和其時間的速率變換方式。但須要值得注意的一點:transition-delay與transition-duration的值都是時間,因此要區分它們在連寫中的位置,通常瀏覽器會根據前後順序決定,第一個能夠解析爲時間的怭值爲transition-duration第二個爲transition-delay。如:
-moz-transition: background 0.5s ease-in,color 0.3s ease-out;
-webkit-transition: background 0.5s ease-in,color 0.3s ease-out;
-o-transition: background 0.5s ease-in,color 0.3s ease-out;
transition: background 0.5s ease-in,color 0.3s ease-out;
}
若是你想給元素執行全部transition效果的屬性,那麼咱們還能夠利用all屬性值來操做,此時他們共享一樣的延續時間以及速率變換方式,如:
-moz-transition: all 0.5s ease-in;
-webkit-transition: all 0.5s ease-in;
-o-transition: all 0.5s ease-in;
transition: all 0.5s ease-in;
}
綜合上述咱們能夠給transition一個速記法:transition: <property> <duration> <animation type> <delay>以下圖所示:
相對應的一個示例代碼:
-webkit-transition: all .5s ease-in-out 1s;
-o-transition: all .5s ease-in-out 1s;
-moz-transition: all .5s ease-in-out 1s;
transition: all .5s ease-in-out 1s;
}
瀏覽器的兼容性:
由於transition最先是有由webkit內核瀏覽器提出來的,mozilla和opera都是最近版本才支持這個屬性,而咱們的大衆型瀏覽器IE全家都是不支持,另外因爲各大現代瀏覽器Firefox,Safari,Chrome,Opera都還不支持W3C的標準寫法,因此在應用transition時咱們有必要加上各自的前綴,最好在放上咱們W3C的標準寫法,這樣標準的會覆蓋前面的寫法,只要瀏覽器支持咱們的transition屬性,那麼這種效果就會自動加上去:
//Mozilla內核 -moz-transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]* //Webkit內核 -webkit-transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]* //Opera -o-transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]* //W3C 標準 transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]*
經過上面,我想你們對CSS3的Transition屬性的使用有必定的概念存在了,下面爲了增強你們在這方面的使用,咱們一塊兒來看下面的DEMO。咱們經過實踐來鞏固前面的理論知識,也經過實踐來增強transition的記憶。
DEMO一:
DEMO一咱們主要是在一個div中放置了幾個小塊,分別是對應了transition-timing-function中的幾種類型,咱們在div的hover狀態下,改變其部分屬性,從而達到一種動畫效果。咱們也可使用jq來點擊一個按鈕,觸發這個div(說簡單點就是經過按鈕的點擊事件給這個div加上一個class,讓其子元素都觸發相對應的transition動畫效果),爲了讓你們能更好的學習和理解,我把相應的代碼貼在這裏,感興趣的朋友就跟着作一下吧,也能夠直接把代碼複製到你本地頁面運行查看效果。
Html Code:
<div id="timings-demo">
<div id="ease" class="demo-box">Ease</div>
<div id="ease-in" class="demo-box">Ease-in</div>
<div id="ease-out" class="demo-box">Ease-out</div>
<div id="ease-in-out" class="demo-box">Ease-in-out</div>
<div id="linear" class="demo-box">Linear</div>
<div id="cubic-bezier" class="demo-box">Cubic-bezier</div>
</div>
CSS Code:
border: 1px solid #ccc;
padding: 10px;
height: 400px;
width: 400px;
}
.demo-box {
width: 100px;
height: 50px;
text-align: center;
line-height: 50px;
text-align: center;
color: #fff;
background: #96c;
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
border-radius: 5px;
-moz-box-shadow: inset 0 0 5px rgba(102, 153, 0,0.5);
-webkit-box-shadow: inset 0 0 5px rgba(102, 153, 0,0.5);
box-shadow: inset 0 0 5px rgba(102, 153, 0,0.5);
margin-bottom: 10px;
}
//ease效果:
#ease {
-moz-transition: all 5s ease 0.3s;
-webkit-transition: all 5s ease 0.3s;
-o-transition: all 5s ease 0.3s;
transition: all 5s ease 0.3s;
background: #f36;
}
//ease-in效果:
#ease-in {
-moz-transition: all 3s ease-in 0.5s;
-webkit-transition: all 3s ease-in 0.5s;
-o-transition: all 3s ease-in 0.5s;
transition: all 3s ease-in 0.5s;
background: #369;
}
//ease-out效果:
#ease-out {
-moz-transition: all 5s ease-out 0s;
-webkit-transition: all 5s ease-out 0s;
-o-transition: all 5s ease-out 0s;
transition: all 5s ease-out 0s;
background: #636;
}
//ease-in-out效果:
#ease-in-out {
-moz-transition: all 1s ease-in-out 2s;
-webkit-transition: all 1s ease-in-out 2s;
-o-transition: all 1s ease-in-out 2s;
transition: all 1s ease-in-out 2s;
background: #3e6;
}
//linear效果:
#linear {
-moz-transition: all 6s linear 0s;
-webkit-transition: all 6s linear 0s;
-o-transition: all 6s linear 0s;
transition: all 6s linear 0s;
background: #999;
}
//cubic-bezier效果:
#cubic-bezier {
-moz-transition: all 4s cubic-bezier 1s;
-webkit-transition: all 4s cubic-bezier 1s;
-o-transition: all 4s cubic-bezier 1s;
transition: all 4s cubic-bezier 1s;
background: #6d6;
}
//hover狀態下或單擊click按鈕後demo-box產生屬性變化
#timings-demo.timings-demo-hover .demo-box,
#timings-demo:hover .demo-box {
-moz-transform: rotate(360deg) scale(1.2);
-webkit-transform: rotate(360deg) scale(1.2);
-o-transform: rotate(360deg) scale(1.2);
transform: rotate(360deg) scale(1.2);
background: #369;
border: 1px solid rgba(255,230,255,08);
-moz-border-radius: 25px;
-webkit-border-radius: 25px;
border-radius: 25px;
margin-left: 280px;
height: 30px;
line-height: 30px;
margin-bottom: 15px;
}
使用單擊事件給dimings-demo加上一個timings-demo-hover的class名,使用demo-bxo產生屬性變化
$("#timings-demo-btn").toggle(
function(){
$(this).next("div#timings-demo").addClass("timings-demo-hover");
},function(){
$(this).next("div#timings-demo").removeClass("timings-demo-hover");
});
咱們來看看其效果圖
未改變屬性效果
正在變換中
執行完動畫後的最終效果
上圖是鼠標移動到#timings-demo的div產生的效果變換示意圖,你單擊「click」按鈕一樣會產生上面的一個動畫效應,爲了節約空間,這裏不在貼出示意圖。