transition主要包含四個屬性值:
執行變換的屬性:transition-property
,
變換延續的時間:transition-duration
,
在延續時間段,變換的速率變化transition-timing-function
,
變換延遲時間transition-delay
。
下面分別來看這四個屬性值css
語法:web
transition-property : none | all | [ <IDENT> ] [ ',' <IDENT> ]*
transition-property
是用來指定當元素其中一個屬性改變時執行transition效果,其主要有如下幾個值:none(沒有屬性改變);all(全部屬性改變)這個也是其默認值;indent(元素屬性名)。當其值爲none時,transition立刻中止執行,當指定爲all時,則元素產生任何屬性值變化時都將執行transition效果,ident是能夠指定元素的某一個屬性值。其對應的類型以下:segmentfault
具體什麼css屬性能夠實現transition效果,在W3C官網中列出了全部能夠實現transition效果的CSS屬性值以及值的類型,你們能夠點這裏瞭解詳情。這裏須要提醒一點是,並非什麼屬性改變都爲觸發transition動做效果,好比頁面的自適應寬度,當瀏覽器改變寬度時,並不會觸發transition的效果。但上述表格所示的屬性類型改變都會觸發一個transition動做效果。瀏覽器
語法:ide
transition-duration : <time> [, <time>]*
transition-duration
是用來指定元素 轉換過程的持續時間,取值:<time>爲數值,單位爲s(秒)或者ms(毫秒),能夠做用於全部元素,包括:before和:after僞元素。其默認值是0,也就是變換時是即時的。函數
語法:動畫
transition-timing-function : ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier(<number>, <number>, <number>, <number>) [, ease | linear | ease-in | ease-out | ease-in-out | cubic-bezier(<number>, <number>, <number>, <number>)]*
取值:spa
transition-timing-function
的值容許你根據時間的推動去改變屬性值的變換速率,transition-timing-function有6個可能值:code
語法:orm
transition-delay : <time> [, <time>]*
transition-delay
是用來指定一個動畫開始執行的時間,也就是說當改變元素屬性值後多長時間開始執行transition效果,其取值:<time>爲數值,單位爲s(秒)或者ms(毫秒),其使用和transition-duration極其類似,也能夠做用於全部元素,包括:before和:after僞元素。 默認大小是"0",也就是變換當即執行,沒有延遲。
有時咱們不僅改變一個css效果的屬性,而是想改變兩個或者多個css屬性的transition效果,那麼咱們只要把幾個transition的聲明串在一塊兒,用逗號(「,」)隔開,而後各自能夠有各自不一樣的延續時間和其時間的速率變換方式。但須要值得注意的一點:transition-delay與transition-duration的值都是時間,因此要區分它們在連寫中的位置,通常瀏覽器會根據前後順序決定,第一個能夠解析爲時間的怭值爲transition-duration
,第二個爲transition-delay
。如:
a { -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
屬性值來操做,此時他們共享一樣的延續時間以及速率變換方式,如:
a { -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>以下圖所示:
相對應的一個示例代碼:
p { -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; }