`

IE6 PNG透明终极解决方案(打造W3Cfuns-IE6PNG最强帖)

 
阅读更多

 

 

       本文版权归W3Cfuns.com所有,转载需在文章页面明显位置以链接的方式给出原文链接,否则W3Cfuns.com将根据《中华人民共和国著作权法》向北京市人民法院提交相关材料,追究侵权责任。

       “珍惜生命,远离IE6”,IE6中的bug令很多Web前端开发人员实为头疼,因此不知道烧了多少脑细胞,在众多的Bug中最令人抓狂的就是IE对png图片的不支持,导致设计师和重构师放弃了很多很炫的效果,为了让大家在这方面少烧点脑细胞,KwooShung我就舍身一把,把当前最流行最实用的IE6支持PNG图片的方案整理到本贴内,以供大家学习参考!





方案1 - 滤镜解决方案:

介绍:滤镜从IE4.0被微软正式引入,所以我们可以使用滤镜解决IE6的PNG透明问题,滤镜不仅可以实现目前CSS3的一些旋转效果而且还可以引入图片。注意:此方法在部分版本的IETest中无效,建议使用标准的IE6来进行测试!


目录说明:
<ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;">




思路:
        1、书写正常的CSS代码,通过background导入图片,这样所有的浏览器均使用了此PNG图片;
              background:url(../images/W3CfunsLogo.png);


        2、通过滤镜对引入图片,滤镜引入图片的时候是相对于HTML文件,而不是相对于CSS文件,语法如下:
              filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src="images/W3CfunsLogo.png");

              代码写到这里,我们放到IE6下测试后发现IE6还是没有透明,因为我们虽然设置了滤镜引入图片,但是background也同样加载了此图片,又因为background的图层比滤镜设置的高,所以才没有显示出来,如下图:

<ignore_js_op style="word-wrap: break-word;">




        3、所以我们得出的结论就是当我们使用filter的时候,就要使background失效,因此我们可以使用CSSHack来解决此问题(如果您不知道IE6的CSSHack如何使用的话,请看这里!),只需要将IE6的background:none;即可,那么可以得出的代码如下:
             _background:none; /*此代码只有IE6识别*/

             又因为filter只在IE6下让其产生作用,IE6+版本的浏览器虽然也识别filter,但是png透明是没有灰底问题的,所以我们同样将filter也加上IE6 Hack即可。


        4、最终我们可以得到如下代码:
              #pics
              {
                      background:url(../images/W3CfunsLogo.png) no-repeat;

                      /*以下为IE6设置PNG透明代码*/
                      _background:none;
                      _filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src="images/W3CfunsLogo.png");
              }



        提示:如果需要使其支持链接的hover,那么需要在CSS中定义:cursor:pointer;使其呈现手型,否则将为默认的鼠标状态。


优点:
        1、绿色无插件;
        2、效率高,速度快;
        3、网速慢的时候,不会出现先灰底再透明的情况,支持远程图片;
        4、支持Hover等伪类,但是得使用两张图片,网速慢的情况下,会导致第二张图片暂时无法显示,因为还没有完全载入;


缺点:
        1、不支持平铺,虽然filter有sizingMethod="scale", 拉伸缩放模式,但是图片会变形,如果单纯的颜色或简单的渐变色还能横向平铺;
        2、不支持Img标签;
        3、不支持CSS Sprite;


使用情况:
        1、当没有img引入png时可考虑;
        2、当没有CSS Sprite需求时可考虑;
        3、当没有平铺需求时候可考虑;



滤镜解决方案 - DEMO入口




方案2 - HTC插件解决方案:

介绍:从IE 5.5版本开始,Internet Explorer(IE)开始支持Web 行为的概念。这些行为是由后缀名为.htc的脚本文件描述的,它们定义了一套方法和属性,程序员几乎可以把这些方法和属性应用到HTML页面上的任何元素上去。


目录说明:
<ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;">




思路:
        1、首先下载压缩文件 <ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;"> htc.zip (2.27 KB, 下载次数: 2107) 
        2、复制并粘贴iepngfix.htc和blank.gif到您的网站文件夹中。
        3、在需要使用的PNG标签上定义如下,相对于HTML文件的位置 (不相对于CSS文件!)。例如,你可能看起来像这样:
              <style type="text/css">
                      img,div{behavior:url(style/iepngfix.htc);}
              </style>

        5、如果您的网站使用的子文件夹,打开。HTC文件,大约在第16行更改blankImg变量,修改blank.gif路径像这样:同样路径相对于HTML文件的位置 (不相对于CSS文件!)。
             IEPNGFix.blankImg = "images/blank.gif";

        6、复制并粘贴iepngfix.htc和blank.gif到您的网站文件夹中。
        <script type="text/javascript" src="js/iepngfix_tilebg.js"></script>

        7、由于此js只有使用IE6时才有用,所以为了让我们的页面更加高效的执行,我们可以将上方代码修改如下,只有IE6的时候才调用执行此JavaScript:
        <!--[if IE 6]><script type="text/javascript" src="../js/iepngfix_tilebg.js"></script><![endif]-->


优点:
        1、一次性配置好,只需要像平时一样引入png图片,也不需要考虑png相对于html路径的问题,当目录有所变化,只需要修改htc文件或css中htc文件路径即可。
        2、支持平铺属性。
        3、不支持Img标签;
        4、不支持Hover等伪类;


缺点:
        1、多引入了js、图片和htc,共三个文件;
        2、不支持CSS Sprite;
        3、当文件载入之前,会先暂时呈现灰底;


使用情况:
        1、当没有img引入png时可考虑;
        2、当没有CSS Sprite需求时可考虑;
        3、PNG图片比较频繁修改时可考虑;


htc解决方案 - DEMO入口





方案3 - 纯CSS解决方案:

介绍:虽说是纯CSS解决方案,但是也使用了JavaScript来运算,只不过是将脚本写到了CSS文件中,遗憾的是,此方案只支持img标签,对背景图片无效。


目录说明:
<ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;">




思路:
        1、首先下载透明的图片文件 <ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;"> blank.zip (707 Bytes, 下载次数: 1350) 
        2、在需要设置透明的样式中加入下方代码,其中蓝色标注代码为刚才下载的透明图片,路径同样还是相对于HTML文件的位置 (不相对于CSS文件!)
              img
              {
                      _azimuth:expression(this.pngSet?this.pngSet=true:(this.nodeName == "IMG" && this.src.toLowerCase().indexOf('.png')>-1?(this.runtimeStyle.backgroundImage = "none",this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.src + "', sizingMethod='image')",this.src ="images/blank.gif"):(this.origBg = this.origBg? this.origBg :this.currentStyle.backgroundImage.toString().replace('url("','').replace('")',''),this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.origBg + "', sizingMethod='crop')",this.runtimeStyle.backgroundImage = "none")),this.pngSet=true);
              }


优点:
        CSS代码看起来似乎很优雅,至少没有乱七八糟的文件了,基本没有外加的文件,效率还算不错。


缺点:
        1、多引入了一个本不应该存在的blank.gif图片文件;
        2、不支持背景图即Background;
        3、当文件载入之前,会先暂时呈现灰底;
        4、不支持Hover等伪类;


使用情况:
        1、大部分透明的png存在于img标签中时可考虑;
        2、如果有背景图的可以参考上面所说的支持背景图的两种方式;


纯css解决方案 - DEMO入口





方案4 - 原生JavaScript解决方案:

介绍:利用了方案1的滤镜原理来实现,但由于此javascript没有读取css文件中的样式,所以此方案同样只支持img标签,对背景图片无效。


目录说明:
<ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;">




思路:
        1、首先下载透明此方案所用到的js文件 <ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;"> iepngfix.zip (1.25 KB, 下载次数: 2012) 
        2、由于此js只有使用IE6时才有用,所以为了让我们的页面更加高效的执行,我们可以将上方代码修改如下,只有IE6的时候才调用执行此JavaScript:
        <!--[if IE 6]><script type="text/javascript" src="js/iepngfix.js"></script><![endif]-->


优点:
        代码看起来似乎很优雅,基本没有外加的文件,效率还算不错。


缺点:
        1、额外加入了js文件,增加http请求;
        2、不支持背景图即Background;
        3、当文件载入之前,会先暂时呈现灰底;
        4、不支持Hover等伪类;


使用情况:
        1、大部分透明的png存在于img标签中时可考虑;
        2、如果有背景图的可以参考上面所说的支持背景图的两种方式;


原生JavaScript解决方案 - DEMO入口





方案5 - jQuery解决方案:

介绍:jQuery为我们带来了很大的方便,jQuery没有让我们有太大的失望,img和png都同时得以支持,唯一美中不足的还是无法平铺,无法使用CSS Sprite。


目录说明:
<ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;">




思路:
        1、首先下载此方案所用到的js文件和透明gif <ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;"> jQueryPngFix.zip (2.7 KB, 下载次数: 2644) 
        2、找到js文件中找到blankgif: 'images/blank.gif',将路径修改为相对于HTML文件的位置 (不相对于CSS或js文件!)
        3、由于此js只有使用IE6时才有用,所以为了让我们的页面更加高效的执行,我们可以将上方代码修改如下,只有IE6的时候才调用执行此JavaScript:
        <!--[if IE 6]><script type="text/javascript" src="js/pngfix.js"></script><![endif]-->


优点:
        1、CSS代码看起来很优雅,只需要引入js进行简单的配置一下就行了,效率还算不错;
        2、支持背景图,支持img;


缺点:
        1、额外加入了js文件和图片文件,增加http请求;
        2、加载了一个庞大的jQuery类库;
        3、多库共存的时候可能会出现问题;
        4、不支持平铺;
        5、不支持CSS Sprite;
        6、当文件载入之前,会先暂时呈现灰底;
        7、不支持Hover等伪类;


使用情况:
        当您的项目中使用jQuery的时可以考虑;


jQuery解决方案 - DEMO入口





方案6 - PNG8格式的图片解决方案:

介绍:png8和gif都是8位的透明度,IE6与生俱来就支持png8的索引色透明度,但不支持png或8位以上的 alpha 透明度。而对于非动画的GIF建议你使用PNG8,因为体积会更小~

思路:一个最简单也最保险的方法让IE6支持PNG图片透明(小小的分享一下)

优缺点:点击此处前往





方案7 - DD_belatedPNG解决方案:

介绍:我们都知道在目前所用的png图片透明解决方案基本都是使用滤镜、xpression解决的、透明gif替代。但是这些方法都有一个缺点,就是不支持CSS中backgrond-position与background-repeat。而这次的js插件使用了微软的VML语言进行绘制且不需要引入其他文件,一个小小的js就可以完美解决png图片bug就连img标签和hover伪类也可以很好的解决。


目录说明:
<ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;">




思路:
        1、首先下载此方案所用到的文件, <ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;"> DD_belatedPNG.zip (3.76 KB, 下载次数: 3420) 
        2、引入刚下载的js文件,同样由于此js只有使用IE6时才有用,所以为了让我们的页面更加高效的执行,我们可以将上方代码修改如下,只有IE6的时候才调用执行此JavaScript:
        <!--[if IE 6]><script type="text/javascript" src="js/DD_belatedPNG.js"></script><![endif]-->
        3、调用函数,设置参数如下:
              DD_belatedPNG.fix("#pngImg,#pics,#picsRepeat");

              其中传入的参数为所使用png图片的标签的ID、类样式和标签名称,同样也可以按照下方这样来写
              DD_belatedPNG.fix("#content img");
              此方法则表示#content下的所有img标签透明

              如果为链接和链接的hover设置透明,那么您按照下方这么来写,在部分版本里面可以不用加入:hover直接写选择器即可,但是为了保险,建议咱们还是加上:hover:
              DD_belatedPNG.fix("#links,#link:hover");

              写到这里并且您使用过jQuery或者CSSQuery类库,那么您一定熟悉上面的这种选择方法,总之就是,在CSS中您是如何选择的元素,那么在这个js函数(方法)中传入什么,只不过多个选择的时候,使用逗号隔开即可。


        KwooShung用此方法时的小技巧:如果页面中存在很多png,DD_belatedPNG.fix();函数的参数岂不是很长?我们可以使用这种写法:
             DD_belatedPNG.fix(".pngFix,.pngFix:hover");

             如果使用上述的写法,我们的html中只需要在相对应的标签上加入class="pngFix"就行了,如果有多个类样式,按照平时的多个类样式的写法即可class="abc cbc pngFix"

             使用此方法的时候,我们每次都要加载两个js文件或者写两个<script>标签才行,这样不太好,http请求会增多,那么我们可以打开DD_belatedPNG.js文件,在尾部加入如下代码即可:
             window.onload = function()
             {
                          DD_belatedPNG.fix(".pngFix,.pngFix:hover");
             }

             这样我们只需要引入此JS,在需要透明的标签上加入class="pngFix"即可,简单 · 方便 · 快捷!


优点:
        1、CSS代码无需任何修改,按照平时的思路来写即可;
        2、无需配置;
        3、没有多余的gif图片;
        4、支持img;
        5、支持平铺;
        6、支持CSS Sprite;
        8、支持Hover等伪类;


缺点:
        1、额外加入了js文件(6.39k)和http请求,可以忽略不计;
        2、当文件载入之前,会先暂时呈现灰底;
        3、js文件过多的时候,可能会报错,导致js无法正常运行(这种情况极少出现,可以忽略不计);


使用情况:
        1、当前6种方法均不能解决问题的时候可考虑;
        2、当png图片过多的时候可考虑,因为png图片太多,使用前面的几个方法,有的会导致CSS代码冗余过多,还不如引入此文件划算;


DD_belatedPNG解决方案 - DEMO入口





方案8 - EvPng解决方案:

介绍:此方案与第七种方案差不多,使用方法也如出一辙,效果也非常不错。

目录说明:
<ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;">



思路:
        1、首先下载此方案所用到的文件, <ignore_js_op style="word-wrap: break-word; font-family: 微软雅黑; line-height: 25px; -webkit-text-size-adjust: none;"> EvPng.zip (3.39 KB, 下载次数: 2106) 
        2、参考第七种方案的使用方法。


优点:
        1、CSS代码无需任何修改,按照平时的思路来写即可;
        2、无需配置;
        3、没有多余的gif图片;
        4、支持img;
        5、支持平铺;
        6、支持CSS Sprite;
        8、支持Hover等伪类;


缺点:
        1、额外加入了js文件(文件4.93k,比DD_belatedPNG的6.39k还小)和http请求,可以忽略不计;
        2、当文件载入之前,会先暂时呈现灰底;
        3、js文件过多的时候,可能会报错,导致js无法正常运行(这种情况极少出现,可以忽略不计);
        4、使用CSS Sprite技术的hover效果在部分情况下top可能会有1像素的偏差。


使用情况:
        1、当前7种方法均不能解决问题的时候可考虑;
        2、当DD_belatedPNG效果不理想的时候可以考虑;


方案提供者:本帖60楼,感谢moxuanyuan童鞋的分享。


EvPng解决方案 - DEMO入口

 

 

 

http://www.w3cfuns.com/article-297-1-1.html

分享到:
评论

相关推荐

    W3Cfuns完美解决IE6不支持hover的方法.rar

    标题"**W3Cfuns完美解决IE6不支持hover的方法**"暗示了这个压缩包提供了一个针对这个问题的解决方案。W3Cfuns是一个知名的中文Web开发者社区,它提供了许多关于Web标准、前端技术以及解决兼容性问题的资源和教程。 ...

    W3Cfuns前端开发工具箱

    随着前端开发行业逐渐成熟,前端开发网(W3Cfuns.com)的站长KwooShung研发了一个W3Cfuns前端开发工具箱,帮助广大的前端开发工程师提高研发速度和效率。 已包含工具: 正则表达式调试工具:即使不会正则表达式也能写...

    w3cfuns网站jquery导航条.zip

    本文将深入探讨w3cfuns网站上的jQuery导航条,一个集动画效果和下拉菜单于一体的高效导航方案。 一、jQuery简介 jQuery是一个轻量级、高性能的JavaScript库,它简化了HTML文档遍历、事件处理、动画设计以及Ajax...

    W3cfuns工具

    w3c集成正则、压缩js等小型工具。W3cfuns工具

    W3cfuns 前端开发工具箱

    这个工具箱是W3cfuns社区为前端工程师精心打造的一个综合资源,提供了多种实用工具,涵盖了前端开发的多个方面。 **一、HTML/CSS/JavaScript验证器** 工具箱内包含HTML、CSS和JavaScript的验证器,可以帮助开发者...

    W3Cfuns前端开发工具箱最新绿色版

    W3Cfuns前端开发工具箱最新绿色版这个简直就是前端开发的神器!

    [W3Cfuns]精通CSS:高级Web标准解决方案(第2版)_含目录 pdf

    [W3Cfuns]精通CSS:高级Web标准解决方案(第2版)_含目录 本书汇集了最有用的CSS技术,介绍了CSS的基本概念和最佳实践,结合实例探讨了图像、链接和列表的操纵,还有表单设计、数据表格设计、纯CSS布局等核心CSS技术。...

    jquery w3cfuns网站首页焦点图片弹跳效果滚动代码

    "jQuery W3CFuns网站首页焦点图片弹跳效果滚动代码"是实现这种效果的一种常见方案,它结合了jQuery库的强大功能和W3CFuns网站的优秀设计思想。本文将深入探讨这一特效的实现原理及其实现步骤。 一、jQuery简介 ...

    w3cfuns网站jquery导航条

    "w3cfuns网站jquery导航条"就是一个专为网站设计的交互式导航组件,利用jQuery库来实现动态效果和下拉菜单功能。jQuery是JavaScript的一个强大库,它简化了JavaScript的DOM操作、事件处理和动画设计等任务,使得创建...

    w3cfuns网站首页jquery图片滚动特效代码

    本教程将详细讲解如何实现如w3cfuns网站首页所示的jQuery图片滚动特效,该特效具有左右箭头控制和切换时的抖动动画效果。 首先,我们需要了解jQuery库。jQuery是一个快速、简洁的JavaScript库,它简化了HTML文档...

    W3Cfuns1500个前端开发常用JavaScript特效

    W3Cfuns1500个前端开发常用JavaScript特效集合是一个宝贵的资源库,为开发者提供了丰富的代码示例和灵感来源。这个资源包含了各种各样的特效,包括但不限于动画、表单处理、图像操作、导航菜单、滚动效果、时间日期...

    W3Cfuns前端开发工具箱最新绿色版.rar

    W3Cfuns前端工具是一款功能强大的web前端开发工具,主要功能包括CSS自动生成、代码调试、代码压缩等,支持正则表达式、压缩工具、CSSSprite、json格式化等等,为用户进行web开发提供很多便利条件。有从事web开发的...

    w3cfuns网站首页jquery图片滚动.zip

    本项目“w3cfuns网站首页jquery图片滚动.zip”提供了一个具体的示例,帮助我们理解并学习如何创建此类效果。 首先,我们需要了解HTML5的基础结构。HTML5是目前网页开发的标准,提供了更丰富的语义标签,如`&lt;header&gt;...

    60个网页特效_w3cfuns整理

    在"60个网页特效_w3cfuns整理"这个压缩包中,包含了一系列精心设计的代码片段,旨在帮助开发者和设计师为他们的网站增添各种炫酷效果。这些特效涵盖了网页的各个部分,如导航菜单、滑块、滚动效果、按钮、表单、图像...

    W3Cfuns_JavaScript_DOM编程艺术

    W3Cfuns发布的这个第二版中文版,为国内读者提供了便捷的学习资源,帮助他们掌握JavaScript在网页开发中的核心技能——DOM操作。 DOM(Document Object Model)是HTML和XML文档的标准表示,它将文档结构转化为一个...

    w3cfuns网站jquery导航条特效代码

    本文将深入解析“w3cfuns网站”的一款基于jQuery的导航条特效,该特效具有动画效果和下拉菜单功能,为网页增添互动性和美观性。 首先,jQuery是一个强大的JavaScript库,它简化了JavaScript的DOM操作、事件处理和...

    FrontEndBlogCN:前端博客相关网站搜集

    W3CFUNS 大前端 W3HELP W3SCHOOL HTML5中国 前端乱炖 F2E社区 MDN 个人博客 博客地址 RSS地址 CSS森林 ---- twinsen ---- 艾文王 ---- 余果 ---- 张鑫旭 ---- 大猫 ---- 飘飘 ---- 米随随 ---- 99css ---- 进步博客 ...

Global site tag (gtag.js) - Google Analytics