CSS3陰影實現方法及技巧全解
網頁設計中常常要用到陰影的效果,通過陰影可以比較容易突出一個元素,在沒有CSS3的時候,一般都用圖片做陰影效果,而現在通過使用CSS3的text-shadow和box-shadow這兩個屬性就可以分別設置文字和容器的陰影。這是一種新特性。不過這種特性只在支持CSS3的瀏覽器上有效果,比如:Firefox3.5,Safari 3.1 +,和谷歌瀏覽器等。
容器設置陰影box-shadow
語法:
box-shadow: h-shadow v-shadow blur spread color inset;
以上各屬性值的解析:horizontal(水平):指定水平偏移陰影。正值(即:5px)陰影向右,而為負值(即:- 10px)將使它偏向左。
vertical(垂直):指定垂直偏移陰影。正值(即:5px)會使陰影在框的底部,而負值(即:- 10px)將使它偏向上。
blur(模糊):設置的柔化半徑。默認值為0,這意味著沒有模糊。正值增加了模糊,而負值,實際上縮小了陰影。此屬性默認為0。
spread:陰影的尺寸,該參數為可選參數。0px代表陰影和當前的實體一樣大,大于0則表示大于實體的尺寸。
color(顏色):顏色值,也就是設置陰影顏色。
inset:將外部陰影 (outset) 改為內部陰影。該參數為可選參數。
提醒:該屬性可以加在任意元素上,如圖片,Div,SPAN,P標簽等等都可以。
提醒:該屬性可以加在任意元素上,如圖片,Div,SPAN,P標簽等等都可以。
<html>
<head>
<title>W3Cschool(w3cschool.cn)</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<style type="text/css">
#shadow {
box-shadow: 10px 10px 5px #888888;
width:500px;
padding:5px;
text-align:center;
font-size:20px;
background:#21759b;
margin:0 auto;
color:#ffffff;
}
</style>
</head>
<body>
<div id="shadow">W3Cschool(w3cschool.cn)</div>
</body>
</html>
為了兼容各主流瀏覽器并支持這些主流瀏覽器的較低版本,在基于Webkit的Chrome和Safari等瀏覽器上使用box-shadow屬性時,我們需要將屬性的名稱寫成-webkit-box-shadow的形式。Firefox瀏覽器則需要寫成-moz-box-shadow的形式。
.box-shadow{
//Firefox4.0-
-moz-box-shadow:h-shadow v-shadow blur spread color inset;
//Safariand Google chrome10.0-
-webkit-box-shadow:h-shadow v-shadow blur spread color inset;
//Firefox4.0+、 Google chrome 10.0+ 、 Oprea10.5+ and IE9
box-shadow:h-shadow v-shadow blur spread color inset;
}
注意:出于方便,后文的css屬性有的地方只寫了box-shadow屬性,沒有寫-moz-和-webkit-前綴的形式,在使用中不要忘記加上。為了更清楚的了解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>
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-5在. box-shadow-2效果的基礎上,將外陰影設為內陰影。
注意這樣的寫法是錯誤的:{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-4在. box-shadow-2效果的基礎上添加了陰影擴展半徑15px。
4、. box-shadow-6一個元素使用了多個陰影,多個陰影之間用逗號分隔。給對象四邊設置陰影效果,我們是通過改變x-offset和y-offset的正負值來實現,其中x-offset為負值時,生成左邊陰影,為正值時生成右邊陰影,y-offset為正值是生成底部陰影,為負值時生成頂部陰影。并且把模糊半徑設置為0,如果不設置為0的話那么其他三邊也將會有陰影。這點需要注意!
并且此處還涉及到一個多陰影的順序問題。當給同一個元素使用多個陰影屬性時,需要注意它的順序,最先寫的陰影將顯示在最頂層,如. box-shadow-7設為不同的模糊值:
.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;
}
將只顯示紅色的陰影效果,因為紅色陰影層在上面,模糊半徑大,將后面的黑色陰影完全遮擋。得出的結論是:如果前面的陰影模糊值小于后面的陰影模糊值,那么前面的顯示在后面之上,如果前面陰影的模糊值大于后面的陰影模糊值,那么前面的陰影將遮住后面的陰影效果。
4、類border邊框效果(只設置陰影擴展半徑和陰影顏色)
.box-shadow-9呈現的效果,同boder:1px solid red相似,但box-shadow的效果與border效果在對象高度上有區別,正好要比border高度大一個擴展半徑。而且陰影不影響頁面的任何布局,這一點可以通過查看firebug下的layout圖得以證實。
.box-shadow-9呈現的效果,同boder:1px solid red相似,但box-shadow的效果與border效果在對象高度上有區別,正好要比border高度大一個擴展半徑。而且陰影不影響頁面的任何布局,這一點可以通過查看firebug下的layout圖得以證實。
在ie下模擬css3中的box-shadow陰影效果
方法一:可以使用IE的Shadow濾鏡
基本語法:filter:progid:DXImageTransform.Microsoft.Shadow(color=’顏色值’, Direction=陰影角度(數值),Strength=陰影半徑(數值));
注意:該濾鏡必須配合background屬性一起使用,否則該濾鏡失效。
IE下模擬css3中的box-shadow(陰影)代碼:
注意:該濾鏡必須配合background屬性一起使用,否則該濾鏡失效。
IE下模擬css3中的box-shadow(陰影)代碼:
.box-shadow{
filter: progid:DXImageTransform.Microsoft.Shadow(color='#969696',Direction=135, Strength=5);/*for ie6,7,8*/
background-color: #ccc;
-moz-box-shadow:2px 2px 5px #969696;/*firefox*/
-webkit-box-shadow:2px 2px 5px #969696;/*webkit*/
box-shadow:2px 2px 5px #969696;/*opera或ie9*/
}
li.blk-item{
width:423px;
height:229px;
float:left;
padding:8px;
margin:2px 18px 13px 21px;
display:inline;
border:1px solid #d3c998;
border-radius:2px;
filter:progid:DXImageTransform.Microsoft.Shadow(color='#d3c998', Direction=135,Strength=5);/*for ie6,7,8*/
background-color: #fff;
-moz-box-shadow:2px 2px 5px#d3c998;/*firefox*/
-webkit-box-shadow:2px 2px 5px#d3c998;/*webkit*/
box-shadow:2px 2px 5px #d3c998;/*opera或ie9*/
}
ie-css3.htc是一個可以讓IE瀏覽器支持部份CSS3屬性的htc文件,不只是box-shadow,它還可以讓你的IE瀏覽器支持圓角屬性border-radius和文字陰影屬性text-shadow。
它的使用方法是:下載它并放到你的服務器目錄
在你的<head></head>里面寫入下面的代碼:
這個腳本的缺點是IE只支持一部分的box-shadow值。需要注意:
1、當你使用了這個htc文件后,你的CSS里面,只要寫有box-shadow, -moz-box-shadow或-webkit-box-shadow的任何一種,IE就會渲染。
它的使用方法是:下載它并放到你的服務器目錄
在你的<head></head>里面寫入下面的代碼:
這個腳本的缺點是IE只支持一部分的box-shadow值。需要注意:
1、當你使用了這個htc文件后,你的CSS里面,只要寫有box-shadow, -moz-box-shadow或-webkit-box-shadow的任何一種,IE就會渲染。
2、當使用了這個htc文件后,你不能這樣寫box-shadow: 0 0 10px red; 而應該是box-shadow: 0px 0px 10px red; 否則IE中會失效。
3、不支持RGBA值中的alpha透明度。
4、不支持inset內陰影。
5、不支持陰影擴展。
6、陰影在IE中只會顯示為黑色,不管你設置成其它什么顏色。
方法三:使用jQuery的插件jquery.boxshadow.js
插件的下載地址是:https://www.jq22.com/jquery-info22890
使用方法很簡單,將該文件和jquery版本庫引入head標簽,插入以下js效果代碼:
<script type="text/javascript">
$(document).ready(function(){
if($.browser.msie) {
$('.obj').boxShadow(-10,-10,5,"#0cc"); //obj元素使用了box-shadow
}
});
</script>
注意:js中可以使用:obj.style.webkitBoxShadow=值(字符串);obj.style.MozBoxShadow=值(字符串);obj.style.boxShadow=值(字符串);補充知識:CSS3的屬性
border-top-left-radius:[<length> | <percentage> ] [ <length> | <percentage> ]?
默認值:0
取值:
<length>:
用長度值設置對象的左上角(top-left)圓角半徑長度。不允許負值
<percentage>:
用百分比設置對象的左上角(top-left)圓角半徑長度。不允許負值
說明:
設置或檢索對象的左上角圓角邊框。提供2個參數,2個參數以空格分隔,每個參數允許設置1個參數值,第1個參數表示水平半徑,第2個參數表示垂直半徑,如第2個參數省略,則默認等于第1個參數。 如設置border-top-left-radius:5px10px;表示top-left這個角的水平圓角半徑為5px,垂直圓角半徑為10px。對應的腳本特性為borderTopLeftRadius。
設置文字陰影text-shadow
實際上,text-shadow 并不是在 CSS3 中才設計出的新屬性,早在 CSS 2.0 時已經有了這個屬性,之后在 CSS 2.1 中刪去這個屬性,最終在 CSS3 中重新納入。
語法:
語法:
text-shadow : offset-x || offset-y || opacity || color
該屬性支持4個參數,分別是陰影顏色、陰影的水平延伸距離(陰影的 x 軸偏移)、陰影的垂直延伸距離(陰影的 y 軸偏移)、模糊效果的作用半徑(陰影的長度)。也許這樣介紹概念會有點難以理解,下面直接寫一個小例子進行說明:/* For text-shadow */
#example {text-shadow: 1px 1px 2px #d8d8d8; }
注:代碼中省略與陰影設置無關的 CSS 代碼(下同),完整 CSS 請參考文章末尾 Demo 的源碼。
效果如下:
效果如下:
/* For text-shadow 多重陰影 */
#example-muti {text-shadow: 1px 1px 2px #c10ccc, 1px 1px 2px #648cb4, 1px 1px 6px #cc150c;
}
值得注意的是,在多重陰影中,陰影的順序在不同版本的瀏覽器中表現不一定相同,由于在 CSS2.0 中,代碼中最先定義的陰影會顯示在最下面,而在 CSS3 中,最先定義的陰影則顯示在最上面。在較新版本的現代瀏覽器中(Kayo 測試的是 Chrome 22.0.1229.94 , Firefox 17.0.1 , Safari 5.1.7 , Opera 12.11 )多重陰影的渲染順序都已經按照 CSS3 的順序了,但在早期版本的一些現代瀏覽器中仍會有差異,在介紹瀏覽器支持情況時會再說明一下這部分內容。
相對于圖片來說,現在用一個屬性就能解決問題實在簡便很多。不過,也許你也已經猜到了,杯具的 IE 是不支持 CSS 陰影(所以 IE 版本都不支持 text-shadow IE8 及以下版本不支持 box-shadow ),因此針對 IE ,如果需要達到以上的同樣效果,就需要使用 IE 私有濾鏡 shadow 或 dropshadow 。這兩個濾鏡的具體使用也會有些不一樣,下面詳細介紹:
如果使用 shadow 濾鏡,針對以上例子,開發者可以這樣編寫代碼:
相對于圖片來說,現在用一個屬性就能解決問題實在簡便很多。不過,也許你也已經猜到了,杯具的 IE 是不支持 CSS 陰影(所以 IE 版本都不支持 text-shadow IE8 及以下版本不支持 box-shadow ),因此針對 IE ,如果需要達到以上的同樣效果,就需要使用 IE 私有濾鏡 shadow 或 dropshadow 。這兩個濾鏡的具體使用也會有些不一樣,下面詳細介紹:
如果使用 shadow 濾鏡,針對以上例子,開發者可以這樣編寫代碼:
progid:DXImageTransform.Microsoft.shadow(Color='#d8d8d8', Direction='135', Strength='2'); zoom: 1; }
shadow 濾鏡有三個參數,分別是陰影顏色、陰影偏移角度和陰影長度,其中陰影偏移角度需要通過計算才能獲得,在例子中是 “135” 度。如果你習慣了使用偏移值設置陰影,可以使用另一個濾鏡 dropshadow ,具體寫法如下:
#example-ie {filter: progid:DXImageTransform.Microsoft.DropShadow(OffX='1', OffY='1', Color='#d8d8d8', Positive='true'); zoom: 1; }
效果如下:dropshadow 有四個參數,分別是陰影 x 軸偏移、陰影 y 軸偏移、陰影顏色、最后一個 positive 屬性則決定是否只為非透明像素建立可見的投影,默認值為 true ,即只為非透明像素建立陰影,若為 false ,則也為透明像素建立投影。
以上兩個濾鏡也支持多重陰影,開發者可以按如下方式編寫,但實際效果會遠差于 text-shadow 。
以上兩個濾鏡也支持多重陰影,開發者可以按如下方式編寫,但實際效果會遠差于 text-shadow 。
/* IE 下多重陰影 */
#example-ie-muti {filter: DropShadow(OffX='1', OffY='1', Color='#c10ccc', Positive='true') DropShadow(OffX='1', OffY='1', Color='#648cb4', Positive='true') DropShadow(OffX='1', OffY='1', Color='#cc150c', Positive='true'); zoom: 1; }
另外,在使用以上兩個濾鏡時,還有幾點需要注意的:
1、如果元素同時設置了背景色,那么以上兩個濾鏡將會失效,這是因為 shadow 濾鏡沒有像 CSS 濾鏡那樣區分文字陰影和容器陰影,當開發者為元素設置背景色后,IE 會自動為該元素添加陰影而取消其中文字的陰影。具體會有一個復雜的機制處理這個過程,下面會另作說明。
2、陰影顏色需要使用形如“#aabbcc”這樣的寫法,不能使用“#abc”這樣的簡寫,若使用簡寫,則會自動使用黑色作為陰影顏色而忽略指定的顏色,并且陰影距離也不可控(不采用指定值)。
3、要使到多重陰影有效,元素必須觸發 hasLayout ,最常用的是設置 zoom: 1 或指定元素高度、寬度。另外在 IE7 及以下版本的 IE 中,使用單個濾鏡也需要觸發元素的 hasLayout 。關于 hasLayout ,我們將在今后的文章中另做介紹