陰影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的特徵,用上方代碼來進行更深入的講解。
結論:
1) 從.box-shadow-1的效果可以得出不指定屬性陰影顏色的情況下,陰影在webkit核心下的safari和chrome瀏覽器下表現為透明色,在Firefox/Opera下表現為黑色。

2) 從內外兩個div塊inner、outer的比較來看,所有支援box-shadow的主流瀏覽器都表現為:內層陰影撐破外層容器將整個陰影效果呈現出來。 W3C標準以圖示的方式對box-shadow的原理和表現進行了解讀:

從圖中我們可以了解到:圓角border-radius,陰影擴展半徑、陰影模糊半徑以及padding是如何影響物件陰影的:非零值的border-radius將會以相同的作用影響陰影的外形,但border-image不會影響物件陰影的任何外形;物件陰影同box模型的層次一樣,外陰影會在物件背景之下,內陰影會在邊框之下背景之上。我們知道,預設情形背景圖片是在背景顏色之上的。所以整個層級是:邊框>內陰影>背景圖片>背景顏色>外陰影。
3) 從. box-shadow-2到. box-shadow-5的效果,我們可以了解到box-shadow取值的作用。
. box-shadow-2是xy沒有偏移,陰影大小10px,沒有擴展半徑,顏色#0CC即rgba(0, 204,204, 1),這裡我們使用的是顏色HEX值;效果

而. box-shadow-3是在.box-shadow-2效果的基礎上,應用了rgba顏色值,好處是給box-shadow陰影添加了alpha透明效果。效果:

. box-shadow-4在. box-shadow-2效果的基礎上添加了陰影擴展半徑15px。

. box-shadow-5在. box-shadow-2效果的基礎上,將外陰影設為內陰影。

4). box-shadow-6一個元素使用了多個陰影,多個陰影之間用逗號分隔。給物件四邊設定陰影效果,我們是透過改變x-offset和y-offset的正負值來實現,其中x-offset為負值時,產生左邊陰影,為正值時產生右邊陰影,y-offset為正值是產生底部陰影,為負值時產生頂部陰影。並且把模糊半徑設定為0,如果不設定為0的話那麼其他三邊也會有陰影。這點要注意!

注意這樣的寫法是錯的:{box-shadow:-10px 0 10px red, box-shadow:10px 0 10px blue,box-shadow:0 -10px 10px yellow,box-shadow:0 10px 10px green}
#並且此處也涉及到一個多陰影的順序問題。當給同一個元素使用多個陰影屬性時,需要注意它的順序,最先寫的陰影將顯示在最頂層,如. box-shadow-7設為不同的模糊值:
. box-shadow-7{
box-shadow:0 0 10px 5px black,
0 0 10px## 出層疊的順序效果:

#. box-shadow-8{
box-shadow:0 0 10px 20px red,
紅色的陰影效果,因為紅色陰影層在上面,模糊半徑大,將後面的黑色陰影完全遮擋。
的結論是:如果前面的陰影模糊值小於後面的陰影模糊值,那麼前面的顯示在後面之上,如果前面陰影的模糊值大於後面的陰影模糊值,那麼前面的陰影就會遮住後面的陰影效果。 4) 類別border邊框效果(只設定陰影擴充半徑與陰影顏色)
- 課程推薦
- 課件下載
課件暫不提供下載,工作人員正在整理中,後期請多關注該課程~ 















