IE下实现类似CSS3 text-shadow文字阴影的几种方法


Posted in HTML / CSS onMay 11, 2011

一、开始的擦边话
为了测试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浏览器):
IE下实现类似CSS3 text-shadow文字阴影的几种方法

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属性效果:
IE下实现类似CSS3 text-shadow文字阴影的几种方法

并且对不同颜色的支持效果大相径庭,例如,我们把光晕的黑色改成灰色,看看IE9浏览器下的效果:
IE下实现类似CSS3 text-shadow文字阴影的几种方法

可以看到不仅光晕颜色不纯(杂色丛生),且文字边缘也有不和谐的黑色糙边,让人不仅感叹:你能不能再丑一点。

2. 既然是光晕滤镜,就决定了此方法实现的文字阴影效果是无方向性的,就四周均匀扩散性质的。这是该方法一个较大的局限性。
三、MotionBlur滤镜下的文字阴影效果
IE滤镜中有个名叫MotionBlur的滤镜,用术语称呼其为“动感模糊滤镜”。该滤镜使用的示例如下:

filter:progid:DXImageTransform.Microsoft.MotionBlur(strength=5, direction=145);
用中文释义就是:145度方向上5像是大小的动感模糊。产生的效果基本上就是下面这幅模样:
IE下实现类似CSS3 text-shadow文字阴影的几种方法

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浏览器):

IE下实现类似CSS3 text-shadow文字阴影的几种方法

正所谓人比人,气死人啊。两者的效果差距可以赶上凤姐和志玲姐的差距了。然而,通过某些小手段,我们也可以让MotionBlur滤镜下的文字阴影效果爷变得很赞,这就是下面一节的内容。
四、MotionBlur滤镜下文字阴影效果进一步优化
路上有坑怎么办?很简单,填上就好,如果没有实物填充,盖个盖子什么的也是好的。所以,正如上面说到,文字应用动感滤镜实现投影效果好比割肉补疮,现在,我们只要在被割掉的那块肉上再补上一块不就OK了吗?

您可以狠狠地点击这里:MotionBlur滤镜下文字阴影效果优化demo

结果在IE9浏览器的兼容模式下(貌似是IE7 的核)的效果如下图:
IE下实现类似CSS3 text-shadow文字阴影的几种方法

效果看上去要舒服多了。效果实现的原理是两端一模一样的文字相互重叠,背后的文字动感模糊,前面的文字就是很纯洁的文字了。

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下实现类似CSS3 text-shadow文字阴影的几种方法

在FireFox浏览器下效果为:
IE下实现类似CSS3 text-shadow文字阴影的几种方法

可以发现,此方法实现的效果是真正意义上的兼容,基本上像素毫厘不差。

相关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等浏览器暂时没有机会测试,所以,自己不确定这些浏览器下的表现是否令人满意。如果有什么糟糕的地方,欢迎指正。文中要是有表述不准确的地方也欢迎指正。

感谢阅读。 原创文章,转载请注明来自张鑫旭-鑫空间-鑫生活

HTML / CSS 相关文章推荐
CSS3——齿轮转动关键代码
May 02 HTML / CSS
两种CSS3伪类选择器详细介绍
Dec 24 HTML / CSS
详解CSS3 rem(设置字体大小) 教程
Nov 21 HTML / CSS
HTML5等待加载动画效果
Jul 27 HTML / CSS
HTML5 Canvas画线技巧——实现绘制一个像素宽的细线
Aug 02 HTML / CSS
HTML5 video 事件应用示例
Sep 11 HTML / CSS
HTML5 Canvas中使用用路径描画圆弧
Jan 01 HTML / CSS
HTML5中input[type='date']自定义样式与日历校验功能的实现代码
Jul 11 HTML / CSS
HTML table 表格边框的实现思路
Oct 12 HTML / CSS
详解CSS不定宽溢出文本适配滚动
May 24 HTML / CSS
css实现两栏布局,左侧固定宽,右侧自适应的多种方法
Aug 07 HTML / CSS
MIME类型中application/xml与text/xml的区别介绍
Jan 18 HTML / CSS
CSS3 Backgrounds属性相关介绍
May 11 #HTML / CSS
深入浅出CSS3 background-clip,background-origin和border-image教程
Jan 27 #HTML / CSS
css3 background属性调整增强介绍
Dec 18 #HTML / CSS
利用CSS3的checked伪类实现OL的隐藏显示的方法
Dec 18 #HTML / CSS
CSS3实战第一波 让我们尽情的圆角吧
Aug 27 #HTML / CSS
彻底弄明白CSS3的Media Queries(跨平台设计)
Jul 27 #HTML / CSS
让IE6、IE7、IE8支持CSS3的脚本
Jul 20 #HTML / CSS
You might like
php&amp;java(三)
2006/10/09 PHP
PHP Pear 安装及使用
2009/03/19 PHP
PHP 类相关函数的使用详解
2013/05/10 PHP
如何用php生成扭曲及旋转的验证码图片
2013/06/07 PHP
详解 PHP加密解密字符串函数附源码下载
2015/12/18 PHP
Yii基于CActiveForm的Ajax数据验证用法示例
2016/07/14 PHP
PHP搭建大文件切割分块上传功能示例
2017/01/04 PHP
关于JS字符串函数String.replace()
2013/04/07 Javascript
Chrome下ifame父窗口调用子窗口的问题示例探讨
2014/03/17 Javascript
jQuery实现只允许输入数字和小数点的方法
2016/03/02 Javascript
AngularJS基础 ng-paste 指令简单示例
2016/08/02 Javascript
js实现类bootstrap模态框动画
2017/02/07 Javascript
基于angular2 的 http服务封装的实例代码
2017/06/29 Javascript
微信小程序 本地图片按照屏幕尺寸处理
2017/08/04 Javascript
原生JS实现的多个彩色小球跟随鼠标移动动画效果示例
2018/02/01 Javascript
Vue中this.$router.push参数获取方法
2018/02/27 Javascript
vue实现未登录跳转到登录页面的方法
2018/07/17 Javascript
Bootstrap 模态框自定义点击和关闭事件详解
2018/08/10 Javascript
浅谈vue.use()方法从源码到使用
2019/05/12 Javascript
原生js实现trigger方法示例代码
2019/05/22 Javascript
vue+ElementUI 关闭对话框清空验证,清除form表单的操作
2020/08/06 Javascript
优化Python代码使其加快作用域内的查找
2015/03/30 Python
PyQt5打开文件对话框QFileDialog实例代码
2018/02/07 Python
python实现最大优先队列
2019/08/29 Python
解决Tensorflow 使用时cpu编译不支持警告的问题
2020/02/03 Python
美国山地自行车、露营、户外装备和服装购物网站:Aventuron
2018/05/05 全球购物
求职者应聘的自我评价
2013/10/16 职场文书
汽车运用工程系毕业生自荐信
2013/12/27 职场文书
汽车专业人才自我鉴定范文
2013/12/29 职场文书
父亲追悼会答谢词
2014/01/17 职场文书
《画杨桃》教学反思
2014/04/13 职场文书
护士工作失误检讨书
2014/09/14 职场文书
大学军训的体会
2014/11/08 职场文书
年会邀请函的格式及范文五篇
2019/11/02 职场文书
Spring Boot两种全局配置和两种注解的操作方法
2021/06/29 Java/Android
MyBatis核心源码深度剖析SQL语句执行过程
2022/05/20 Java/Android