1. 程式人生 > >CSS3中輕鬆實現漸變效果

CSS3中輕鬆實現漸變效果

關鍵詞:CSS3漸變效果

漸變可以建立類似於彩虹的效果,低版本的瀏覽器不的不使開發者用圖片來實現,CSS3將會輕鬆實現網頁漸變效果。


要得上面的線性漸變效果,我們這樣去定義CSS3樣式:

background-image: -moz-linear-gradient(top, #8fa1ff, #3757fa); /* Firefox */
background-image: -webkit-gradient(linear, left top, left bottom, color-stop(0, #ff4f02), color-stop(1, #8f2c00)); /* Saf4+, Chrome */
filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#c6ff00', endColorstr='#538300', GradientType='0'); /* IE*/

-moz-linear-gradient有三個引數。第一個引數表示線性漸變的方向,top是從上到下、left是從左到右,如果定義成left top,那就是從左上角到右下角。第二個和第三個引數分別是起點顏色和終點顏色。你還可以在它們之間插入更多的引數,表示多種顏色的漸變。

-webkit-gradient是webkit引擎對漸變的實現引數,一共有五個。

第一個引數表示漸變型別(type),可以是linear(線性漸變)或者radial(徑向漸變)。

第二個引數和第三個引數,都是一對值,分別表示漸變起點和終點。這對值可以用座標形式表示,也可以用關鍵值表示,比如 left top(左上角)和left bottom(左下角)。

第四個和第五個引數,分別是兩個color-stop函式。color-stop函式接受兩個引數,第一個表示漸變的位置,0為起點,0.5為中點,1為結束點;第二個表示該點的顏色。

IE依靠濾鏡實現漸變。startColorstr表示起點的顏色,endColorstr表示終點顏色。GradientType表示漸變型別,0為預設值,表示垂直漸變,1表示水平漸變。

線性漸變使用from()以及to()方法指定過渡顏色點:


background: -webkit-gradient(linear, left top, left bottom, from(#96ff00), color-stop(0.5, orange), to(rgb(255, 0, 0)));

線性漸變多個過渡點在同一位置:


background:-webkit-gradient(linear, left top, left bottom, from(#00abeb), to(#fff), color-stop(0.5, #fff), color-stop(0.5, #66cc00));

徑向漸變綜合效果演示:


background: -moz-radial-gradient(30px 30px, circle farthest-corner, #58ff00 0%, rgba(222, 255, 0, 0) 30%),
-moz-radial-gradient(50px 70px, circle farthest-corner, #F30 0%, rgba(255, 159, 34, 0) 60%),
-moz-radial-gradient(80px 10px, circle farthest-corner, #03F 0%, rgba(222, 255, 0, 0) 80%);
background:-webkit-gradient(radial, 105 105, 20, 112 120, 50, from(#ff5f98), to(rgba(255,1,136,0)), color-stop(75%, #ff0188)),
-webkit-gradient(radial, 95 15, 15, 102 20, 40, from(#00c9ff), to(rgba(0,201,255,0)), color-stop(80%, #00b5e2)),
-webkit-gradient(radial, 0 150, 50, 0 140, 90, from(#f4f201), to(rgba(228, 199,0,0)), color-stop(80%, #e4c700));

circle farthest-corner圓形漸變,ellipse farthest-corner橢圓漸變