css3 transition

W3C標準中對css3transition這是樣描述的:“css的transition允許css的屬性值在一定的時間區間內平滑地過渡。這種效果可以在鼠標單擊、獲得焦點、被點擊或對元素任何改變中觸發,并圓滑地以動畫效果改變CSS的屬性值。”
下面我們同樣從其最語法和屬性值開始一步一步來學習transition的具體使用
語法:
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。下面分別來看這四個屬性值
一、transition-property:
語法:
transition-property : none | all | [ <IDENT> ] [ ',' <IDENT> ]*

transition-property是用來指定當元素其中一個屬性改變時執行transition效果,其主要有以下幾個值:none(沒有屬性改變);all(所有屬性改變)這個也是其默認值;indent(元素屬性名)。當其值為none時,transition馬上停止執行,當指定為all時,則元素產生任何屬性值變化時都將執行transition效果,ident是可以指定元素的某一個屬性值。其對應的類型如下:
1、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等屬性;
3、percentage:真實的數字 如:word-spacing,width,vertical-align,top,right,bottom,left,min-width,min-height,max-width,max-height,line-height,height,background-position等屬性;
4、integer離散步驟(整個數字),在真實的數字空間,以及使用floor()轉換為整數時發生 如:outline-offset,z-index等屬性;
5、number真實的(浮點型)數值,如:zoom,opacity,font-weight,等屬性;
6、transform list:詳情請參閱:《CSS3 Transform
7、rectangle:通過x, y, width 和 height(轉為數值)變換,如:crop
8、visibility: 離散步驟,在0到1數字范圍之內,0表示“隱藏”,1表示完全“顯示”,如:visibility
9、shadow: 作用于color, x, y 和 blur(模糊)屬性,如:text-shadow
10、gradient: 通過每次停止時的位置和顏色進行變化。它們必須有相同的類型(放射狀的或是線性的)和相同的停止數值以便執行動畫,如:background-image
11、paint server (SVG): 只支持下面的情況:從gradient到gradient以及color到color,然后工作與上面類似
12、space-separated list of above:如果列表有相同的項目數值,則列表每一項按照上面的規則進行變化,否則無變化
13、a shorthand property: 如果縮寫的所有部分都可以實現動畫,則會像所有單個屬性變化一樣變化
具體什么css屬性可以實現transition效果,在W3C官網中列出了所有可以實現transition效果的CSS屬性值以及值的類型,大家可以點這里了解詳情。這里需要提醒一點是,并不是什么屬性改變都為觸發transition動作效果,比如頁面的自適應寬度,當瀏覽器改變寬度時,并不會觸發transition的效果。但上述表格所示的屬性類型改變都會觸發一個transition動作效果。
二、transition-duration:
語法:
transition-duration : <time> [, <time>]*

transition-duration是用來指定元素 轉換過程的持續時間,取值:<time>為數值,單位為s(秒)或者ms(毫秒),可以作用于所有元素,包括:before和:after偽元素。其默認值是0,也就是變換時是即時的。
三、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的值允許你根據時間的推進去改變屬性值的變換速率,transition-timing-function有6個可能值:
1、ease:(逐漸變慢)默認值,ease函數等同于貝塞爾曲線(0.25, 0.1, 0.25, 1.0).
2、linear:(勻速),linear 函數等同于貝塞爾曲線(0.0, 0.0, 1.0, 1.0).
3、ease-in:(加速),ease-in 函數等同于貝塞爾曲線(0.42, 0, 1.0, 1.0).
4、ease-out:(減速),ease-out 函數等同于貝塞爾曲線(0, 0, 0.58, 1.0).
5、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.


其他幾個屬性的示意圖:

四、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;}

瀏覽器的兼容性:


因為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:
<a id="timings-demo-btn">click</a> <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:

timings-demo { 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產生屬性變化
$(document).ready(function(){ $("#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”按鈕同樣會產生上面的一個動畫效應,為了節約空間,這里不在貼出示意圖。
DEMO二:
我們在來看另外一個DEMO,這個示例是通過CSS3的transition模仿制作jQuery的slideshow效果,當然這種效果跟js和jQ制作出來的是沒得比,但有時還是可以用一用的,以前騰訊就使用過這樣的一個效果。我們這個DEMO實現的效果原理跟上一個DEMO極其相似,這里我們是通過select的change事件來觸slideshow的CSS3屬性變化,這里應用到一部分jQuery,主要是制作數字切換和前一張下一張的按鈕,以及select的change事件。下面我把代碼貼出以供大家參考,如果你跟著做了的話,你會覺得CSS3的transition真的是魅力是無窮的。
Html Code:
<div id="demoSliderContainer"> <ul id="demoSlider" class="slide-images"> <li class="slide-image">
<span>Monsters Inc</span> </li> <li class="slide-image">
<span>Nemo</span> </li> <li class="slide-image">
<span>Up</span> </li> <li class="slide-image">
<span>Wall-E</span> </li> </ul> <div class="options"> <a href="javascript:;" class="prevSlide">Prev</a> <span class="slide-pager"> <a href="" class="javascript:;">1</a> <a href="" class="javascript:;">2</a> <a href="" class="javascript:;">3</a> <a href="" class="javascript:;">4</a> </span> <a href="javascript:;" class="nextSlide">Next</a> </div> </div> <div id="options"> <label for="transitionEffect">Transition effect :</label> <select id="transitionEffect"> <option value="transition-opacity">opacity fade</option> <option value="transition-left">left slide</option> <option value="transition-right">right slide</option> <option value="transition-top">top slide</option> <option value="transition-bottom">bottom slide</option> <option value="transition-zoom">zoom</option> <option value="transition-dezoom">de-zoom</option> <option value="transition-cornerzoom">corner zoom</option> <option value="transition-rotate">rotate</option> </select> </div>

CSS Code:

demoSliderContainer { background: #000; -moz-box-shadow: 1px 1px 5px #000; -webkit-box-shadow: 1px 1px 5px #000; box-shadow: 1px 1px 5px #000; padding: 0; overflow: auto; margin: 10px auto; width: 560px;} #demoSlider { border: 1px solid #000; border-width: 5px 5px 0; height: 220px; margin: 0 auto; width: 550px; overflow: hidden; position: relative;} .slide-images .slide-image { position: absolute;} .slide-images .slide-image img { z-index: 2;} .slide-images .slide-image span { background: rgba(0,0,0,0.3); -moz-border-radius: 5px 0 0 0; -webkit-border-radius: 5px 0 0 0; border-radius: 5px 0 0 0; bottom: 4px; color: rgba(255,255,255,0.8); font-size: 14px; font-weight: bold; padding: 5px 10px; position: absolute; right: 0; z-index: 3;}.slide-images .slide-image.current img { z-index: 12;} .slide-images .slide-image.current span { z-index: 13;} #demoSliderContainer .options { padding: 3px 10px; text-align: center;}#demoSliderContainer .options a { color: #91BECC; font-family: Georgia,Serif; font-size: 12px; font-weight: bold; text-decoration: none;}#demoSliderContainer .options a:hover { color: #D3E5EB;}#demoSliderContainer .slide-pager a { -moz-transition-duration: 0.5s; -webkit-transition-duration: 0.5s; -o-transition-duration: 0.5s; transition-duration: 0.5s;}#demoSliderContainer .slide-pager a.current { background-color: #91BECC; border-radius: 5px 5px 5px 5px; color: black; padding: 0 4px;}#demoSliderContainer .options .prevSlide { float: left;}#demoSliderContainer .options .nextSlide { float: right;} /transition effect/.slide-images .slide-image,.slide-images .slide-image img { -moz-transition-duration: 1.5s; -webkit-transition-duration: 1.5s; -otransition-duration: 1.5s; transition-duration: 1.5s; } .slide-images.transition-opacity .slide-image { opacity: 0; width: 0; } .slide-images.transition-opacity .slide-image.current { opacity: 1; width: 550px; } .slide-images.transition-left .slide-image { left: -550px; opacity: 0; } .slide-images.transition-left .slide-image.current { left: 0; opacity: 1; } .slide-images.transition-right .slide-image { right: -550px; opacity: 0; } .slide-images.transition-right .slide-image.current { right: 0; opacity: 1; } .slide-images.transition-top .slide-image { opacity: 0; top: -220px; } .slide-images.transition-top .slide-image.current { opacity: 1; top: 0; } .slide-images.transition-bottom .slide-image { opacity: 0; bottom: -220px; } .slide-images.transition-bottom .slide-image.current { opacity: 1; bottom: 0; } .slide-images.transition-cornerzoom .slide-image { opacity: 0; } .slide-images.transition-cornerzoom .slide-image.current { opacity: 1; } .slide-images.transition-cornerzoom .slide-image img { width: 0; } .slide-images.transition-cornerzoom .slide-image.current img { width: 550px; } .slide-images.transition-zoom .slide-image { opacity: 0; } .slide-images.transition-zoom .slide-image.current { opacity: 1; } .slide-images.transition-zoom .slide-image img { left: -275px; position: relative; top: -110px; width: 1100px; } .slide-images.transition-zoom .slide-image.current img { left: 0; top: 0; width: 550px; } .slide-images.transition-dezoom .slide-image { -moz-box-shadow: 2px 2px 8px black; -webkit-box-shadow: 2px 2px 8px black; box-shadow: 2px 2px 8px black; opacity: 0; } .slide-images.transition-dezoom .slide-image.current { opacity: 1; } .slide-images.transition-dezoom .slide-image img { left: 275px; position: relative; top: 110px; width: 0; } .slide-images.transition-dezoom .slide-image.current img { left: 0; top: 0; width: 550px; } .slide-images.transition-rotate .slide-image { opacity: 0; } .slide-images.transition-rotate .slide-image.current { opacity: 1; } .slide-images.transition-rotate .slide-image img { width: 550; height: 220px; position: relative; left: -550px; top: -220px; } .slide-images.transition-rotate .slide-image.current img { width: 550px; height: 220px; left: 0; top: 0; -moz-transform: rotate(1440deg); -webkit-transform: rotate(1440deg); -o-transform: rotate(1440deg); transform: rotate(1440deg); } #options { margin: 20px auto; padding: 5px; width: 550px; }

jQuery Code:
<script type="text/javascript"> $(document).ready(function(){ $(".slide-images").each(function(){ var slider = $(this); var slides = $(".slide-image",slider); var sliderPages = $(".slide-pager"); //Slide Navigation var currentSlideNum = 0; slides.removeClass("current"); slides.eq(currentSlideNum).addClass("current"); sliderPages.each(function(){ var pages = $("a",this); pages.removeClass("current"); pages.eq(currentSlideNum).addClass("current"); }); var goToSlide = function(slideNum) { slides.eq(currentSlideNum).removeClass("current"); slides.eq(slideNum).addClass("current"); sliderPages.each(function(){ var pages = $("a", this); pages.eq(currentSlideNum).removeClass("current"); pages.eq(slideNum).addClass("current"); }); currentSlideNum = slideNum; }; var nextSlide = function() { var nextSlideNum = currentSlideNum + 1; if(nextSlideNum >= slides.size()) nextSlideNum = 0; goToSlide(nextSlideNum); }; var prevSlide = function() { var prevSlideNum = currentSlideNum - 1; if(prevSlideNum < 0) prevSlideNum = slides.size() - 1; goToSlide(prevSlideNum); }; //transition effects var setTransitionEffect = function(transitionEffect) { slider.attr("class","slide-images "+ transitionEffect); }; $("#transitionEffect").change(function(){ setTransitionEffect($(this).val()); }).change(); //Navigation binding $(".prevSlide").click(prevSlide); $(".nextSlide").click(nextSlide); $(".slide-pager a").each(function(i){ if(i >= slides.size()) return false; $(this).click(function(){ goToSlide(i); }); }); //Auto next slide var lastHumanNav = 0; $(".prevSlide, .nextSlide, .slide-pager a").click(function(){ lastHumanNav = new Date().getTime(); }); setInterval(function(){ var now = new Date().getTime(); if(now - lastHumanNav > 5000) nextSlide(); },5000); }); }); </script>

記得在你的本地頁面頭部加上jQuery的版本庫文件。
效果示意圖:


DEMO二思路來自于Greweb.fr并在其基礎上增加了right silde,bottom silde,rotate三種效果,如果你感興趣的話可以在這個基礎上增加更多的slideshow效果,比如利用transform的scale,skew等制作出更出色的效果。
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。原文: https://www.w3cplus.com/content/css3-transition ? w3cplus.com

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容

  • 上一篇介紹了CSS3里transform變形屬性,本篇介紹另一個人氣動畫屬性transition。transiti...
    張歆琳閱讀 25,059評論 1 31
  • CSS3有transition、transform這些屬性,它們是用來移動元素過渡元素之類的。 transform...
    sakatayui醬閱讀 646評論 0 0
  • Transition and animations 貝塞爾曲線在線工具(需翻墻) 貝塞爾曲線在線工具(無需翻墻)...
    ilaoke閱讀 950評論 1 5
  • 一、首先學習的是transition屬性(zoom不支持transition,適用于具體數值的屬性值變化或者背景圖...
    Farewell_V587閱讀 1,228評論 1 3
  • 今日靜心方向:星幣1 從云里伸出一只手,穩穩的拖著一枚黃燦燦的星幣。特別喜歡這個星幣,感覺這個星幣很大很厚實,還水...
    塔羅師默默閱讀 217評論 0 0