HTML 學習筆記 CSS3(過分 transition)

經過 CSS3,咱們能夠在不使用 Flash 動畫或 JavaScript 的狀況下,當元素從一種樣式變換爲另外一種樣式時爲元素添加效果。
請把鼠標移動到下面的元素上:css

先看一下這個代碼 實現旋轉放大的效果:html

<html>
    <head>
        <meta charset="UTF-8">
        <title></title>
        <style type="text/css">
            .anim_transition {
                width: 100px;
                height: 70px;
                background-color: green;
                text-align: center;
                color: white;
                border-radius: 5px;
                transition: all 2s linear;
            }
            .anim_transition:hover {
                width: 150px;
                height: 105px;
                -webkit-transform: rotate(360deg);
            }
        </style>
        <script>
            
        </script>
    </head>
    <body>
        <div id="matrixBox" class="anim_transition">css3過分</div>

    </body>
</html>

先看一下 關於 transition的屬性css3

若是簡寫的話 就能夠這樣寫:web

transition:property 時間 過分方式 延時時長

例如:瀏覽器

transition: width 2s, height 2s, transform 2s linear 2s;

表示同時過分寬度  高度 和 transform 過渡時間爲2秒 過分方式爲勻速 延時2秒開始過渡。函數

上面就是泛泛而談 下面咱們來具體介紹一下:學習

W3C標準中對CSS3的transition是這樣描述的:css的transition容許css的屬性值在必定的時間區域內平滑的過渡。這種效果能夠在鼠標單擊 得到焦點 被點擊活着對元素的任何改變中觸發,並圓滑的以動畫效果改變CSS的屬性值。動畫

transition的語法spa

 transition : [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'> [, [<'transition-property'> || <'transition-duration'> || <'transition-timing-function'> || <'transition-delay'>]]* 

transition主要包括四個屬性值:執行變換的屬性transition-property,變換延續的時間transition-duration,變換的速率變化transition-timing-function,變換延時的時間transition-delay。code

一 transition-property

語法:

 transition-property : none | all | [ <IDENT> ] [ ',' <IDENT> ]*

transition-property是用來指定當元素其中一個屬性改變時執行transition效果,其主要有如下幾個值:none(沒有屬性改變)all(全部屬性改變) 這個也是默認值;indent(元素屬性名)。當其值爲none時,transition立刻中止執行,當指定爲all時,則元素產生任何屬性值變化時都將執行transition效果。indent是能夠指定元素的某一個屬性值。其對應的類型以下:

一、color: 經過紅、綠、藍和透明度組件變換(每一個數值處理)如:background-color,border-color,color,outline-color等css屬性;

2.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:

七、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> [, <time>]* 

transition-duration是用來指定元素 轉換過程的持續時間,取值:<time>爲數值,單位爲s(秒)或者ms(毫秒),能夠做用於全部元素,包括:before和:after僞元素。其默認值是0,也就是變換時是即時的

3、transition-timing-function:

語法:

 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>)]* 

取值:

transition-timing-function的值容許你根據時間的推動去改變屬性值的變換速率,有六個可能的值。

1.ease (逐漸變慢) 默認值 ease函數等同於貝塞爾曲線()

一、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)

6.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 : <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;
}

瀏覽器的兼容性:

先這樣 之後學習到更高深的知識,會回來補充的。原博地址:http://www.w3cplus.com/content/css3-transition

相關文章
相關標籤/搜索