網(wǎng)頁設(shè)計(jì)中常常要用到陰影的效果,,通過陰影可以比較容易突出一個(gè)元素,,在沒有CSS3的時(shí)候,,一般都用圖片做陰影效果,,而現(xiàn)在通過使用CSS3的text-shadow和box-shadow這兩個(gè)屬性就可以分別設(shè)置文字和容器的陰影,。這是一種新特性。 不過這種特性只在支持CSS3的瀏覽器上有效果,,比如:Firefox3.5,,Safari 3.1 +,和谷歌瀏覽器等,。 容器設(shè)置陰影box-shadow語法: box-shadow: h-shadow v-shadow blur spread color inset; 以上各屬性值的解析: horizontal(水平):指定水平偏移陰影,。正值(即:5px)陰影向右,而為負(fù)值(即:- 10px)將使它偏向左,。
spread:陰影的尺寸,,該參數(shù)為可選參數(shù)。0px代表陰影和當(dāng)前的實(shí)體一樣大,,大于0則表示大于實(shí)體的尺寸,。
inset:將外部陰影 (outset) 改為內(nèi)部陰影,。該參數(shù)為可選參數(shù),。 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屬性時(shí),我們需要將屬性的名稱寫成-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的特征,做幾個(gè)小測試,,看效果: 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內(nèi)核下的safari和chrome瀏覽器下表現(xiàn)為透明色,,在Firefox/Opera下表現(xiàn)為黑色,。
從圖中我們可以了解到:圓角border-radius,陰影擴(kuò)展半徑,、陰影模糊半徑以及padding是如何影響對象陰影的:非零值的border-radius將會(huì)以相同的作用影響陰影的外形,,但border-image不會(huì)影響對象陰影的任何外形;對象陰影同box模型的層次一樣,,外陰影會(huì)在對象背景之下,,內(nèi)陰影會(huì)在邊框之下背景之上,。 我們知道,,默認(rèn)情形背景圖片是在背景顏色之上的。所以整個(gè)層級(jí)是:邊框>內(nèi)陰影>背景圖片>背景顏色>外陰影,。 3,、從. box-shadow-2到. box-shadow-5的效果,我們可以了解到box-shadow取值的作用,。
而. 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è)陰影之間用逗號(hào)分隔。給對象四邊設(shè)置陰影效果,,我們是通過改變x-offset和y-offset的正負(fù)值來實(shí)現(xiàn),,其中x-offset為負(fù)值時(shí),生成左邊陰影,,為正值時(shí)生成右邊陰影,,y-offset為正值是生成底部陰影,為負(fù)值時(shí)生成頂部陰影,。 并且把模糊半徑設(shè)置為0,,如果不設(shè)置為0的話那么其他三邊也將會(huì)有陰影。這點(diǎn)需要注意,! 注意這樣的寫法是錯(cuò)誤的:{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:0 0 10px 5px black, 0 0 10px 20px red;} 將能看出層疊的順序效果: 如果將兩個(gè)陰影效果調(diào)一下,,改為如下: .box-shadow-8{ box-shadow:0 0 10px 20px red, 0 0 10px 5px black;} 將只顯示紅色的陰影效果,因?yàn)榧t色陰影層在上面,,模糊半徑大,,將后面的黑色陰影完全遮擋。 得出的結(jié)論是:如果前面的陰影模糊值小于后面的陰影模糊值,,那么前面的顯示在后面之上,,如果前面陰影的模糊值大于后面的陰影模糊值,那么前面的陰影將遮住后面的陰影效果,。 4,、類border邊框效果(只設(shè)置陰影擴(kuò)展半徑和陰影顏色) 在ie下模擬css3中的box-shadow陰影效果方法一:可以使用IE的Shadow濾鏡 基本語法:filter:progid:DXImageTransform.Microsoft.Shadow(color=’顏色值’, Direction=陰影角度(數(shù)值),Strength=陰影半徑(數(shù)值)); .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*/ } 六一兒童節(jié)的專題案例 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*/ } 方法二:有些js和.htc的hack文件可以實(shí)現(xiàn)IE中的陰影效果 ie-css3.htc是一個(gè)可以讓IE瀏覽器支持部份CSS3屬性的htc文件,,不只是box-shadow,它還可以讓你的IE瀏覽器支持圓角屬性border-radius和文字陰影屬性text-shadow,。 這個(gè)腳本的缺點(diǎn)是IE只支持一部分的box-shadow值,。需要注意: 1、當(dāng)你使用了這個(gè)htc文件后,,你的CSS里面,,只要寫有box-shadow, -moz-box-shadow或-webkit-box-shadow的任何一種,IE就會(huì)渲染,。 2,、當(dāng)使用了這個(gè)htc文件后,你不能這樣寫box-shadow: 0 0 10px red; 而應(yīng)該是box-shadow: 0px 0px 10px red; 否則IE中會(huì)失效,。 3,、不支持RGBA值中的alpha透明度。 4,、不支持inset內(nèi)陰影,。 5、不支持陰影擴(kuò)展,。 6,、陰影在IE中只會(huì)顯示為黑色,,不管你設(shè)置成其它什么顏色。 方法三:使用jQuery的插件jquery.boxshadow.js 插件的下載地址是http://www./testcenter/js/jquery/boxshadow/jquery.boxshadow.js 使用方法很簡單,,將該文件和jquery版本庫引入head標(biāo)簽,,插入以下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=值(字符串); 補(bǔ)充知識(shí):CSS3的屬性 border-top-left-radius:[length> | percentage> ] [ length> | percentage> ]? 默認(rèn)值:0 取值: 用長度值設(shè)置對象的左上角(top-left)圓角半徑長度。不允許負(fù)值 用百分比設(shè)置對象的左上角(top-left)圓角半徑長度,。不允許負(fù)值 說明: 設(shè)置或檢索對象的左上角圓角邊框,。提供2個(gè)參數(shù),2個(gè)參數(shù)以空格分隔,,每個(gè)參數(shù)允許設(shè)置1個(gè)參數(shù)值,,第1個(gè)參數(shù)表示水平半徑,第2個(gè)參數(shù)表示垂直半徑,,如第2個(gè)參數(shù)省略,,則默認(rèn)等于第1個(gè)參數(shù),。 如設(shè)置border-top-left-radius:5px10px;表示top-left這個(gè)角的水平圓角半徑為5px,,垂直圓角半徑為10px。對應(yīng)的腳本特性為borderTopLeftRadius,。 實(shí)際上,,text-shadow 并不是在 CSS3 中才設(shè)計(jì)出的新屬性,早在 CSS 2.0 時(shí)已經(jīng)有了這個(gè)屬性,,之后在 CSS 2.1 中刪去這個(gè)屬性,,最終在 CSS3 中重新納入。 該屬性支持4個(gè)參數(shù),,分別是陰影顏色,、陰影的水平延伸距離(陰影的 x 軸偏移)、陰影的垂直延伸距離(陰影的 y 軸偏移),、模糊效果的作用半徑(陰影的長度),。也許這樣介紹概念會(huì)有點(diǎn)難以理解,下面直接寫一個(gè)小例子進(jìn)行說明: 注:代碼中省略與陰影設(shè)置無關(guān)的 CSS 代碼(下同),,完整 CSS 請參考文章末尾 Demo 的源碼,。 另外,text-shadow 也支持多重陰影,,例如,,要為一個(gè)文字同時(shí)設(shè)置三重陰影,可以這樣編寫代碼: 效果如下: 值得注意的是,,在多重陰影中,,陰影的順序在不同版本的瀏覽器中表現(xiàn)不一定相同,由于在 CSS2.0 中,,代碼中最先定義的陰影會(huì)顯示在最下面,,而在 CSS3 中,,最先定義的陰影則顯示在最上面。 在較新版本的現(xiàn)代瀏覽器中(Kayo 測試的是 Chrome 22.0.1229.94 , Firefox 17.0.1 , Safari 5.1.7 , Opera 12.11 )多重陰影的渲染順序都已經(jīng)按照 CSS3 的順序了,,但在早期版本的一些現(xiàn)代瀏覽器中仍會(huì)有差異,,在介紹瀏覽器支持情況時(shí)會(huì)再說明一下這部分內(nèi)容。 這兩個(gè)濾鏡的具體使用也會(huì)有些不一樣,下面詳細(xì)介紹: shadow 濾鏡有三個(gè)參數(shù),分別是陰影顏色,、陰影偏移角度和陰影長度,,其中陰影偏移角度需要通過計(jì)算才能獲得,在例子中是 “135” 度,。如果你習(xí)慣了使用偏移值設(shè)置陰影,,可以使用另一個(gè)濾鏡 dropshadow ,具體寫法如下: 效果如下: dropshadow 有四個(gè)參數(shù),,分別是陰影 x 軸偏移,、陰影 y 軸偏移、陰影顏色,、最后一個(gè) positive 屬性則決定是否只為非透明像素建立可見的投影,,默認(rèn)值為 true ,即只為非透明像素建立陰影,,若為 false ,,則也為透明像素建立投影。 另外,,在使用以上兩個(gè)濾鏡時(shí),,還有幾點(diǎn)需要注意的: 1、如果元素同時(shí)設(shè)置了背景色,那么以上兩個(gè)濾鏡將會(huì)失效,,這是因?yàn)?shadow 濾鏡沒有像 CSS 濾鏡那樣區(qū)分文字陰影和容器陰影,,當(dāng)開發(fā)者為元素設(shè)置背景色后,IE 會(huì)自動(dòng)為該元素添加陰影而取消其中文字的陰影,。具體會(huì)有一個(gè)復(fù)雜的機(jī)制處理這個(gè)過程,,下面會(huì)另作說明。 2,、陰影顏色需要使用形如“#aabbcc”這樣的寫法,,不能使用“#abc”這樣的簡寫,若使用簡寫,,則會(huì)自動(dòng)使用黑色作為陰影顏色而忽略指定的顏色,,并且陰影距離也不可控(不采用指定值)。 3,、要使到多重陰影有效,,元素必須觸發(fā) hasLayout ,最常用的是設(shè)置 zoom: 1 或指定元素高度,、寬度,。另外在 IE7 及以下版本的 IE 中,使用單個(gè)濾鏡也需要觸發(fā)元素的 hasLayout ,。關(guān)于 hasLayout ,,我們將在今后的文章中另做介紹,。 |
|