陰影box-shadow(二)
<!DOCTYPE html> <html> <head> <meta content="text/html; charset=utf-8" http-equiv="Content-Type"> <title>CSS3屬性:box-shadow測試</title> <script type="text/javascript" src="js/jquery.min.js"></script> <script type="text/javascript" src="js/jquery.boxshadow.js"></script> <style type="text/css"> .box-shadow-1{ -webkit-box-shadow: 3px 3px 3px; -moz-box-shadow: 3px 3px 3px; box-shadow: 3px 3px 3px; } .box-shadow-2{ -webkit-box-shadow:0 0 10px #0CC; -moz-box-shadow:0 0 10px #0CC; box-shadow:0 0 10px #0CC; } .box-shadow-3{ -webkit-box-shadow:0 0 10px rgba(0, 204, 204, .5); -moz-box-shadow:0 0 10px rgba(0, 204, 204, .5); box-shadow:0 0 10px rgba(0, 204, 204, .5); } .box-shadow-4{ -webkit-box-shadow:0 0 10px 15px #0CC; -moz-box-shadow:0 0 10px 15px #0CC; box-shadow:0 0 10px 15px #0CC; } .box-shadow-5{ -webkit-box-shadow:inset 0 0 10px #0CC; -moz-box-shadow:inset 0 0 10px #0CC; box-shadow:inset 0 0 10px #0CC; } .box-shadow-6{ box-shadow:-10px 0 10px red, /*左邊陰影*/ 10px 0 10px yellow, /*右邊陰影*/ 0 -10px 10px blue, /*頂部陰影*/ 0 10px 10px green; /*底邊陰影*/ } .box-shadow-7{ box-shadow:0 0 10px 5px black, 0 0 10px 20px red; } .box-shadow-8{ box-shadow:0 0 10px 20px red, 0 0 10px 5px black; } .box-shadow-9{ box-shadow: 0 0 0 1px red; } .obj{ width:100px; height:100px; margin:50px auto; background:#eee; } .outer{ width: 100px; height: 100px; border: 1px solid red; } .inner{ width: 60px; height: 60px; background-color: red; -webkit-box-shadow: 50px 50px blue; -moz-box-shadow: 50px 50px blue; box-shadow: 50px 50px blue; } </style> </head> <body> <div class="obj box-shadow-1"></div> <div class="outer"> <div class="inner"></div> </div> <div class="obj box-shadow-2" ></div> <div class="obj box-shadow-3" ></div> <div class="obj box-shadow-4" ></div> <div class="obj box-shadow-5" ></div> <div class="obj box-shadow-6" ></div> <div class="obj box-shadow-7" ></div> <div class="obj box-shadow-8" ></div> <div class="obj box-shadow-9" ></div> <script type="text/javascript"> $(document).ready(function(){ if($.browser.msie) { $('.obj').boxShadow(-10,-10,5,"#0cc"); //obj元素使用了box-shadow } }); </script> </body> </html>
為了更清楚的了解box-shadow的特徵,用上方代碼來進(jìn)行更深入的講解。
結(jié)論:
1)? 從.box-shadow-1的效果可以得出不指定屬性陰影顏色的情況下,陰影在webkit核心下的safari和chrome瀏覽器下表現(xiàn)為透明色,在Firefox/Opera下表現(xiàn)為黑色。
????????
2)? 從內(nèi)外兩個(gè)div塊inner、outer的比較來看,所有支援box-shadow的主流瀏覽器都表現(xiàn)為:內(nèi)層陰影撐破外層容器將整個(gè)陰影效果呈現(xiàn)出來。 W3C標(biāo)準(zhǔn)以圖示的方式對box-shadow的原理和表現(xiàn)進(jìn)行了解讀:
從圖中我們可以了解到:圓角border-radius,陰影擴(kuò)展半徑、陰影模糊半徑以及padding是如何影響物件陰影的:非零值的border-radius將會以相同的作用影響陰影的外形,但border-image不會影響物件陰影的任何外形;物件陰影同box模型的層次一樣,外陰影會在物件背景之下,內(nèi)陰影會在邊框之下背景之上。我們知道,預(yù)設(shè)情形背景圖片是在背景顏色之上的。所以整個(gè)層級是:邊框>內(nèi)陰影>背景圖片>背景顏色>外陰影。
3)? 從. box-shadow-2到. box-shadow-5的效果,我們可以了解到box-shadow取值的作用。
. box-shadow-2是xy沒有偏移,陰影大小10px,沒有擴(kuò)展半徑,顏色#0CC即rgba(0, 204,204, 1),這裡我們使用的是顏色HEX值;效果
而. box-shadow-3是在.box-shadow-2效果的基礎(chǔ)上,應(yīng)用了rgba顏色值,好處是給box-shadow陰影添加了alpha透明效果。效果:
. box-shadow-4在. box-shadow-2效果的基礎(chǔ)上添加了陰影擴(kuò)展半徑15px。
. box-shadow-5在. box-shadow-2效果的基礎(chǔ)上,將外陰影設(shè)為內(nèi)陰影。
4). box-shadow-6一個(gè)元素使用了多個(gè)陰影,多個(gè)陰影之間用逗號分隔。給物件四邊設(shè)定陰影效果,我們是透過改變x-offset和y-offset的正負(fù)值來實(shí)現(xiàn),其中x-offset為負(fù)值時(shí),產(chǎn)生左邊陰影,為正值時(shí)產(chǎn)生右邊陰影,y-offset為正值是產(chǎn)生底部陰影,為負(fù)值時(shí)產(chǎn)生頂部陰影。並且把模糊半徑設(shè)定為0,如果不設(shè)定為0的話那麼其他三邊也會有陰影。這點(diǎn)要注意!
?
注意這樣的寫法是錯的:{box-shadow:-10px 0 10px red, box-shadow:10px 0 10px blue,box-shadow:0 -10px 10px yellow,box-shadow:0 10px 10px green}
?
#並且此處也涉及到一個(gè)多陰影的順序問題。當(dāng)給同一個(gè)元素使用多個(gè)陰影屬性時(shí),需要注意它的順序,最先寫的陰影將顯示在最頂層,如. box-shadow-7設(shè)為不同的模糊值:
. box-shadow-7{
???????? box-shadow:0 0 10px 5px black,
???????? 0 0 10px##???????出層疊的順序效果:
#. box-shadow-8{
???????? box-shadow:0 0 10px 20px red,
???????紅色的陰影效果,因?yàn)榧t色陰影層在上面,模糊半徑大,將後面的黑色陰影完全遮擋。
的結(jié)論是:如果前面的陰影模糊值小於後面的陰影模糊值,那麼前面的顯示在後面之上,如果前面陰影的模糊值大於後面的陰影模糊值,那麼前面的陰影就會遮住後面的陰影效果。 4)? 類別border邊框效果(只設(shè)定陰影擴(kuò)充半徑與陰影顏色)