IE下實現類似CSS3 text-shadow文字陰影的幾種方法


IE下實現類似CSS3 text-shadow文字陰影的幾種方法

一、開始的擦邊話

為了測試IE9瀏覽器,下午晃晃盪盪把系統換成window7的了。果然,正如網上所傳言的一樣,IE9瀏覽器確實不支持CSS3 text-shadow屬性,且根據最近的IE10 preview版的反饋,IE10瀏覽器也是不支持text-shadow屬性的。至於為何不支持,就像女孩的心思一樣,我也是百思不得其解。

不過考慮到text-shadow的更多的是效果性質的屬性,且潛力有限,所以,就我個人而言,最近版本的IE瀏覽器不支持該屬性我還是相對比較淡然的。雖然IE瀏覽器不支持text-shadow文字陰影屬性,但是我們可以使用一些特殊的手段,或是方法實現類似於文字陰影的效果,而本文就將簡單展示幾種我所知的方法。

二、glow濾鏡下的文字陰影效果

IE濾鏡中有個名叫glow的濾鏡,用來實現光暈效果,於是,我們可以用來實現無方向的文字陰影效果。

該濾鏡最簡單的使用類似下面:

filter:glow(color=black,strength=5);

上面實現的效果就是5像素擴散大小的黑色光暈,效果類似下面(截自IE9瀏覽器):
光暈效果濾鏡下的文字效果 張鑫旭-鑫空間-鑫生活

您可以狠狠地點擊這里:glow濾鏡下文字陰影效果demo

demo頁面中效果想對應的CSS代碼如下:

.bg{width:512px; height:340px; margin:1em auto; background:url(http://image.zhangxinxu.com/image/study/s/s512/mm19.jpg);}
.font{margin:0; padding:1em; color:#fff; text-shadow:0 0 5px rgb(0, 0, 0); font-size:36px; font-family:"微軟雅黑"; float:left; filter:glow(color=black, strength=5);

對應HTML代碼如下:

<div class="bg">
    <h4 class="font">張小姐長大了!</h4>
</div>

不足
1. 雖然IE瀏覽器的glow光暈濾鏡可以實現勉強可以稱為的文字陰影效果,但是其效果相比原生的text-shadow屬性就是玄彬和郭德綱的區別,如下firefox4下的text-shadow屬性效果:
Firefox4下的效果 張鑫旭-鑫空間-鑫生活

並且對不同顏色的支持效果大相徑庭,例如,我們把光暈的黑色改成灰色,看看IE9瀏覽器下的效果:
灰色光暈下的效果 張鑫旭-鑫空間-鑫生活

可以看到不僅光暈顏色不純(雜色叢生),且文字邊緣也有不和諧的黑色糙邊,讓人不僅感嘆:你能不能再丑一點。

2. 既然是光暈濾鏡,就決定了此方法實現的文字陰影效果是無方向性的,就四周均勻擴散性質的。這是該方法一個較大的局限性。

三、MotionBlur濾鏡下的文字陰影效果

IE濾鏡中有個名叫MotionBlur的濾鏡,用術語稱呼其為“動感模糊濾鏡”。該濾鏡使用的示例如下:

filter:progid:DXImageTransform.Microsoft.MotionBlur(strength=5, direction=145);

用中文釋義就是:145度方向上5像是大小的動感模糊。產生的效果基本上就是下面這幅模樣:
動感模糊的文字陰影效果demo 張鑫旭-鑫空間-鑫生活

您可以狠狠地點擊這里:MotionBlur濾鏡下文字陰影效果demo

demo頁面中相關的CSS代碼如下:

.bg{width:512px; height:340px; margin:1em auto; background:url(http://image.zhangxinxu.com/image/study/s/s512/mm19.jpg);}
.font{margin:0; padding:1em; color:#fff; font-size:36px; font-family:"微軟雅黑"; text-shadow:1px 1px 5px #fff; filter:progid:DXImageTransform.Microsoft.MotionBlur(strength=5, direction=145); float:left;}

對應HTML代碼與上面一致,如下:

<div class="bg">
    <h4 class="font">張小姐長大了!</h4>
</div>

不足
1. MotionBlur濾鏡雖然有了方向性,也可以設定大小,但是,其模糊出來的投影顏色卻只能是文字本身的顏色。也就是說,單單一個標簽,一個濾鏡是無法實現類似於文字白色,投影黑色這種效果的。但是,這種先天性的不足也是可以通過某些手段修復的。

2. 此濾鏡在應用動感模糊的同時本身也被模糊了,相對於挖自己身上的肉填飽自己飢餓的肚子。這種實現效果顯然是會大打折扣的,看看正經八百text-shadow屬性下的白色投影效果(圖片截自chrome瀏覽器):
Chrome瀏覽器下的文字投影效果 張鑫旭-鑫空間-鑫生活

正所謂人比人,氣死人啊。兩者的效果差距可以趕上鳳姐和志玲姐的差距了。然而,通過某些小手段,我們也可以讓MotionBlur濾鏡下的文字陰影效果爺變得很贊,這就是下面一節的內容。

四、MotionBlur濾鏡下文字陰影效果進一步優化

路上有坑怎么辦?很簡單,填上就好,如果沒有實物填充,蓋個蓋子什么的也是好的。所以,正如上面說到,文字應用動感濾鏡實現投影效果好比割肉補瘡,現在,我們只要在被割掉的那塊肉上再補上一塊不就OK了嗎?

您可以狠狠地點擊這里:MotionBlur濾鏡下文字陰影效果優化demo

結果在IE9瀏覽器的兼容模式下(貌似是IE7 的核)的效果如下圖:
兼容模式下的動感模糊濾鏡下的效果 張鑫旭-鑫空間-鑫生活

效果看上去要舒服多了。效果實現的原理是兩端一模一樣的文字相互重疊,背后的文字動感模糊,前面的文字就是很純潔的文字了。

CSS代碼如下:

.bg{width:512px; height:340px; margin:1em auto; background:url(http://image.zhangxinxu.com/image/study/s/s512/mm19.jpg);}
.font{margin:0; padding:1em; font-size:36px; font-family:"微軟雅黑";}
.text{color:#fff; position:absolute;}
.sh{color:#000; text-shadow:1px 1px 5px #000; filter:progid:DXImageTransform.Microsoft.MotionBlur(strength=5, direction=145); *zoom:1;}

HTML代碼如下:

<div class="bg">
    <h4 class="font"><span class="text">張小姐長大了!</span><div class="sh">張小姐長大了!</div></h4>
</div>

考慮到不同IE瀏覽器下的兼容性問題,作為陰影效果的文字標簽需要使用block水平的標簽,且需要在IE6/IE7瀏覽器下haslayout。另外,這里的文字重疊是借助了absolute絕對定位元素的無高度性和無寬度性實現的。具體可參見我之前的“CSS 相對/絕對(relative/absolute)定位系列(二)”以及相關系列的文章。

不足
由於要借助於兩段不同的文字實現效果,所以,此方法不使用與長篇大論文字處的投影效果實現,像是標題啊,導航啊這些文字不是很多的地方就可以使用使用。

五、遠離text-shadow和濾鏡的文字陰影實現

這里實現的原理的精髓其實跟上面的其實一致,兩段一模一樣的文字,重疊顯示,不過,投影效果是通過兩段文字的錯位差實現的,例如通過margin負值讓上下的文字出現1像素的偏移。

您可以狠狠地點擊這里:margin錯位下的文字投影效果demo

在IE下的效果如下圖:
IE下的文字投影效果 張鑫旭-鑫空間-鑫生活

在FireFox瀏覽器下效果為:
Firefox瀏覽器下的文字陰影效果 張鑫旭-鑫空間-鑫生活

可以發現,此方法實現的效果是真正意義上的兼容,基本上像素毫厘不差。

相關CSS代碼如下:

.bg{width:512px; height:340px; margin:1em auto; background:url(http://image.zhangxinxu.com/image/study/s/s512/mm19.jpg);}
.font{margin:0; padding:1em; font-size:36px; font-family:"微軟雅黑"; float:left;}
.sh{margin:-1px 0 0 -1px; color:#fff; position:absolute;}

HTML代碼如下:

<div class="bg">
    <h4 class="font"><span class="sh">張小姐長大了!</span><div>張小姐長大了!</div></h4>
</div>

不足
文字陰影效果的大小有限,且無法很好的實現透明度變化的投影效果。1像素的偏移投影是其最適用的情況。

六、快速的結語

就當文章寫到這兒的時候,我突然想到,IE下還有個模糊濾鏡,如果結合文字重疊技術,豈不第一個例子的四周擴散型投影效果有了較好的UI表現。不過礙於自己精力有限,門衛師傅也要休息,這里就不折騰了,有興趣您可以嘗試下IE模糊濾鏡(blur)下的文字投影效果。

當然,一個人的智慧畢竟有限。如果您有比較好的實現文字陰影效果的方法,歡迎分享。

另外,由於重裝系統的原因,IE8,IE6等瀏覽器暫時沒有機會測試,所以,自己不確定這些瀏覽器下的表現是否令人滿意。如果有什么糟糕的地方,歡迎指正。文中要是有表述不准確的地方也歡迎指正。

感謝閱讀。

原創文章,轉載請注明來自張鑫旭-鑫空間-鑫生活[http://www.zhangxinxu.com]
本文地址:http://www.zhangxinxu.com/wordpress/?p=1613


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM