珍惜生命,远离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="data: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="data: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入口

解决IE6中 PNG图片透明的终极方案-八种方案!的更多相关文章

  1. 解决ie6中png图片格式不兼容问题

    在IE6中对图片格式png24支持度不高,如果使用的图片格式是png24,则会导致透明效果无法正常显示 解决方法: 1.可以使用png8来代替png24,即可解决问题,但是使用png8代替png24以 ...

  2. 解决ie6里png图片透明变白色bug

    加入这段js就行了. function correctPNG() // correctly handle PNG transparency in Win IE 5.5 & 6. { var a ...

  3. 解决PNG图片在IE6中背景不透明方法_解决IE6中PNG背

    解决PNG图片在IE6中背景不透明方法_解决IE6中PNG背   目录 解决代码 解决png图片在html中 解决png作为网页背景-css 1.解决PNG图片在IE6中背景不透明的CSS与JS代码 ...

  4. 【IE6的疯狂之二】IE6中PNG Alpha透明(全集)

    ie7,fireofx,opera,及至webkit内核的chrome ,safari….. 这些浏览器均支持png的Alpha透明. 很多人说IE6不支持PNG透明,其实IE支持100%透明的PNG ...

  5. 利用Js或Css滤镜实现IE6中PNG图片半透明效果 IE6PNG妥妥的

    接下来介绍几种PNG图片在IE6中不透明的解决办法 1.用自己的PNG,让IE6一边去吧 首先制作PNG图片的时候,另存为一个GIF图片,因为IE6是支持GIF图片透明,然后在css定义 .pngte ...

  6. 解决IE6下png图片透明度不显示的问题

    世界上最遥远的距离,不外乎我在搞前端,你却在用旧IE,现在随着XP要退休了,IE6的市场占有率应该也会逐步下滑.不过基于天朝人民的惰性以及企鹅微软的“扎篱笆”活动,做网站的朋友依旧不能忽视IE6的存在 ...

  7. 解决iOS中tabBarItem图片默认颜色的问题(指定代码渲染模式为以原样模式的方式显示出来)

    解决iOS中tabBarItem图片默认颜色的问题(指定代码渲染模式为以原样模式的方式显示出来) 解决办法:指定图片的渲染模式(imageWithRenderingMode为:UIImageRende ...

  8. IE6中 PNG 背景透明的最佳解决方案

    为什么要使用 PNG 图片? 简 单来说,使用 PNG 格式比起 GIF 来表现色彩更丰富,特别是表现渐变以及背景透明的渐变要比GIF格式出色很多.目前,最新的浏览器基本上都支持PNG格式.唯独有万恶 ...

  9. 解决IE6中ajax ‘aborted’错误请求中断

    给a标签绑定了一个click事件用来触发ajax请求,在IE6中,请求时常会被中断,在其他浏览器中都一切正常. 在IE6中使用Fiddler2和httpWatch监视请求,经常会出现”aborted” ...

随机推荐

  1. 'java' 不是内部或外部命令,也不是可运行的程序的两个解决办法

    第一个原因: 是环境变量path没有配置好,做如下图配置     第二个原因:   如果java环境有一段时间没有启动,再启动的时候提示这个,解决办法是进入path环境配置,如上图中界面,将JAVA_ ...

  2. .NET4.0 加密通讯协议下TLS 的兼容支持问题.

    Study From https://stackoverflow.com/questions/28286086/default-securityprotocol-in-net-4-5 The defa ...

  3. 13个实用的Linux find命令示例

    除了在一个目录结构下查找文件这种基本的操作,你还可以用find命令实现一些实用的操作,使你的命令行之旅更加简易. 本文将介绍15种无论是于新手还是老鸟都非常有用的Linux find命令. 首先,在你 ...

  4. QVariant相当于一个包含大多数Qt数据类型的联合体(源码解读)

    将数据存储为一个Private结构体类型的成员变量d: <qvariant.cpp> 1 QVariant::QVariant(Type type) 2 { create(type, 0) ...

  5. Jquery 表单提交后3s禁用

    <form action="${pageContext.servletContext.contextPath}/XXX/###" method="post" ...

  6. python自动化之web抓取

    ''' 从web抓取数据: webbrowser:是python自带的,打开浏览器获取指定页面. requests:从因特网上下载文件和网页. Beautiful Soup:解析HTML,即网页编写的 ...

  7. AtCoder Grand Contest 029 翻车记

    A:对于每个B,会和其右边的每个W交换一次. #include<iostream> #include<cstdio> #include<cmath> #includ ...

  8. Genaro Network —— 区块链3.0缔造者

    在2018年1月26日硅谷密探在美国旧金山艺术宫成功举办了“Blockchain Connect Conference”.在大会上,Genaro Network 联合CEO Jason Inch 携同 ...

  9. 洛谷 P2389 电脑班的裁员 解题报告

    题意: 给定一段长为N的序列,选取其中的至多M段使这些子段和最大. 当N=1000时,我们可以采用动态规划解法 令\(dp[i][j][k]\)代表当前选至位置\(i\)处于第\(j\)段当前是否选取 ...

  10. 【bzoj1194】 HNOI2006—潘多拉的盒子

    http://www.lydsy.com/JudgeOnline/problem.php?id=1194 (题目链接) 题意 给出S个自动机,如果一个自动机u的所有状态是另一个自动机v的状态的子集,那 ...