設計師常常使用一些獨特的字體效果和頁面效果,陰影是其中一個,它可以讓頁面中的文字和元素具有立體的效果,從而被突出出來。例如文字陰影,傳統的方法可能需要將文字切出來,直接使用圖片,如果考慮SEO和網站效能,也可能會使用CSS Sprites等技術將圖片整合:
h2{ background:url(sprites.png) no-repeat 0 0; font-size:0; text-indent:-9999em;...}
h2#title1{background-position:0 -30px;}
h2#title2{background-position:0 -60px;}
....
這是很棘手的事情,拼合圖片會花掉你的大量時間,而且為了實現更好視覺效果,你可能還要使用高質量的32位png圖片,這又要讓你面對該死的IE 6的png透明問題!
事實上,對於文字的陰影效果,我們完全可以用CSS來實現!
可以查看查看demo先。
Text-shadow
text-shadow可以讓我們實現完美的文字陰影效果。基本寫法:
text-shadow:[顏色x軸y軸模糊半徑],[顏色x軸y軸模糊半徑]...
或者
text-shadow:[x軸y軸模糊半徑顏色],[x軸y軸模糊半徑顏色]...
這裡的顏色就是陰影的顏色,你可以將顏色寫在前面,也可以寫在最後。 x軸和y軸分別是其陰影的偏移位置,模糊半徑可以理解為陰影長度。而且現在大部分瀏覽器都支援多層陰影,你可以用逗號分開多組設定(當然也可以只是用單一設定)。
範例:
h1{color:#000; background:#333; font:bold 24px/2 "微軟雅黑",Arial;
text-indent:2em;
text-shadow:black 2px 2px 2px; }
效果如下圖:
該屬性目前由除IE之外的大部分瀏覽器支持,對於IE,我們可以使用shadow濾鏡來實現:
filter: Shadow(Color='black', Direction='135', Strength='2')
你可能已經注意到,使用shadow濾鏡只能定義角度direction,而無法定義xy軸,z軸也被換成了strength。注意,使用該濾鏡的時候,不能夠設定背景顏色,否則濾鏡將無效!另外如果你的數學不是很好,不太懂三角函數的演算法,你可以使用IE的另一個濾鏡:dropshadow:
filter: dropshadow(OffX=2, OffY=2, Color='black', Positive='true');
好吧,IE總是會拖我們的後腿,但值得一提的是,IE的這兩個濾鏡是支持多層陰影的!比如,可以這樣寫:
filter: dropshadow(OffX=2, OffY=2, Color='red', Positive='true')
dropshadow(OffX=2, OffY=2, Color='yelow', Positive='true')
dropshadow(OffX=2, OffY=2, Color='blue', Positive='true');
想了解更多關於IE的這兩個濾鏡,請查看: Shadow和Dropshadow
讓我們來看一個多層陰影的例子(這裡無視了IE):
h1{font:bold 32px/2 Verdana, Geneva, sans-serif; color:#f39;
text-shadow:1px 1px 2px rgba(0,0,0,.8), 0 0 1em rgba(255, 0, 255, 0.5), 0 0 0.2em rgba(0, 0, 255, 0.9);
效果如圖:
這裡我們使用到了rgba色彩,它是一種在CSS中同時聲明顏色及其透明度的一種方法,且被大多數A級瀏覽器支援的色彩屬性(除了IE ),了解更多請查看:《 RGBa色彩的瀏覽器支援》-同時我們推薦對於純色半透明的情況使用這種簡單的寫法。
text-shadow的瀏覽器相容性
目前text-shadow被Firefox 3.5+,Safari 1.1+/chrome 2.0+和opera 9.5支持,IE不支持。需要注意的是,Safari只有4.0才支援多層陰影。
box-shadow
先來說IE,IE不支援box-shadow屬性,但上面提到的兩個濾鏡都可以用來實現陰影效果。這也就是說, IE並沒有把文字陰影和盒子陰影區分!這就會出現一些問題:元素中的文字會繼承元素的陰影設定。但如果你不定義該元素的background和border,就只會出現文字陰影,如果只定義background屬性而不定義border,就只會出現盒子陰影,文字不會出現陰影;而如果只定義了border屬性而不定義background,就即會出現盒子陰影,內容文字及圖片也會出現陰影。有興趣的同學可以折騰一下。
好了,現在讓我們忘了IE,來看看box-shadow。事實上,在了解了text-shadow之後,box-shadow就很好理解了,目前只有firefox和safari/chrome透過私有屬性支援box-shadow屬性。而Opera瀏覽器雖然目前還不支援該屬性,但在其文件中提到下一個版本的引擎Presto 2.3(目前最新版的Opera 10.10的引擎是Presto 2.2.15)中將會支援box-shadow,那就讓我們慢慢等待。
box-shadow的語法和text-shadow是一樣的。
#boxShadow{
…
-webkit-box-shadow:2px 2px 2px black;
-moz-box-shadow:2px 2px 2px black;
…
}
事實上,box-shadow和border-radius是很好的搭檔:
#boxShadow1{-moz-border-radius:10px;
-webkit-border-radius:10px;
border-radius:10px;
border:1px solid ddd;
-webkit-box-shadow:0 0 10px black;
-moz-box-shadow:0 0 10px black;
padding:10px;}
效果如圖:
firefox在3.5版本才開始支援box-shadow,目前對陰影的渲染還不是很完美。
總結
CSS陰影是CSS3中很有用的特性,我們已經可以在Firefox/webkit/Opera中使用text-shadow,很快也可以在這些瀏覽器中實作box-shadow。唯獨IE特立獨行,還在堅持它那蹩腳的濾鏡,這真是個杯具。