今天從網(wǎng)上新收集了一個(gè)輕松實(shí)現(xiàn)CSS3中漸變效果,希望可以幫到那些初學(xué)者來(lái)學(xué)習(xí),CSS3技術(shù)。如果覺(jué)得不錯(cuò)可以分享給大家。
漸變可以創(chuàng)建類似于彩虹的效果,低版本的瀏覽器不的不使開(kāi)發(fā)者用圖片來(lái)實(shí)現(xiàn),CSS3將會(huì)輕松實(shí)現(xiàn)網(wǎng)頁(yè)漸變效果。
要得上面的線性漸變效果,我們這樣去定義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有三個(gè)參數(shù)。第一個(gè)參數(shù)表示線性漸變的方向,top是從上到下、left是從左到右,如果定義成left top,那就是從左上角到右下角。第二個(gè)和第三個(gè)參數(shù)分別是起點(diǎn)顏色和終點(diǎn)顏色。你還可以在它們之間插入更多的參數(shù),表示多種顏色的漸變。
-webkit-gradient是webkit引擎對(duì)漸變的實(shí)現(xiàn)參數(shù),一共有五個(gè)。
第一個(gè)參數(shù)表示漸變類型(type),可以是linear(線性漸變)或者radial(徑向漸變)。
第二個(gè)參數(shù)和第三個(gè)參數(shù),都是一對(duì)值,分別表示漸變起點(diǎn)和終點(diǎn)。這對(duì)值可以用坐標(biāo)形式表示,也可以用關(guān)鍵值表示,比如 left top(左上角)和left bottom(左下角)。
第四個(gè)和第五個(gè)參數(shù),分別是兩個(gè)color-stop函數(shù)。color-stop函數(shù)接受兩個(gè)參數(shù),第一個(gè)表示漸變的位置,0為起點(diǎn),0.5為中點(diǎn),1為結(jié)束點(diǎn);第二個(gè)表示該點(diǎn)的顏色。
IE依靠濾鏡實(shí)現(xiàn)漸變。startColorstr表示起點(diǎn)的顏色,endColorstr表示終點(diǎn)顏色。GradientType表示漸變類型,0為缺省值,表示垂直漸變,1表示水平漸變。
線性漸變使用from()以及to()方法指定過(guò)渡顏色點(diǎn):
background: -webkit-gradient(linear, left top, left bottom, from(#96ff00), color-stop(0.5, orange), to(rgb(255, 0, 0)));
線性漸變多個(gè)過(guò)渡點(diǎn)在同一位置:
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橢圓漸變