您好,欢迎访问一九零五行业门户网

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

方案1 - 滤镜解决方案:
介绍:滤镜从ie4.0被微软正式引入,所以我们可以使用滤镜解决ie6的png透明问题,滤镜不仅可以实现目前css3的一些旋转效果而且还可以引入图片。注意:此方法在部分版本的ietest中无效,建议使用标准的ie6来进行测试!
目录说明:
思路:
        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的图层比滤镜设置的高,所以才没有显示出来,如下图:
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页面上的任何元素上去。
目录说明:
思路:
        1、首先下载压缩文件  htc.zip (2.27 kb, 下载次数: 2851) 
        2、复制并粘贴iepngfix.htc和blank.gif到您的网站文件夹中。
        3、在需要使用的png标签上定义如下,相对于html文件的位置 (不相对于css文件!)。例如,你可能看起来像这样:
5、如果您的网站使用的子文件夹,打开。htc文件,大约在第16行更改blankimg变量,修改blank.gif路径像这样:同样路径相对于html文件的位置 (不相对于css文件!)。
             iepngfix.blankimg = images/blank.gif;
6、复制并粘贴iepngfix.htc和blank.gif到您的网站文件夹中。
7、由于此js只有使用ie6时才有用,所以为了让我们的页面更加高效的执行,我们可以将上方代码修改如下,只有ie6的时候才调用执行此javascript:
优点:
        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标签,对背景图片无效。
目录说明:
思路:
        1、首先下载透明的图片文件  blank.zip (707 bytes, 下载次数: 1923) 
        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标签,对背景图片无效。
目录说明:
思路:
        1、首先下载透明此方案所用到的js文件  iepngfix.zip (1.25 kb, 下载次数: 2810) 
        2、由于此js只有使用ie6时才有用,所以为了让我们的页面更加高效的执行,我们可以将上方代码修改如下,只有ie6的时候才调用执行此javascript:
优点:
        代码看起来似乎很优雅,基本没有外加的文件,效率还算不错。
缺点:
        1、额外加入了js文件,增加http请求;
        2、不支持背景图即background;
        3、当文件载入之前,会先暂时呈现灰底;
        4、不支持hover等伪类;
使用情况:
        1、大部分透明的png存在于img标签中时可考虑;
        2、如果有背景图的可以参考上面所说的支持背景图的两种方式;
原生javascript解决方案 - demo入口
方案5 - jquery解决方案:
介绍:jquery为我们带来了很大的方便,jquery没有让我们有太大的失望,img和png都同时得以支持,唯一美中不足的还是无法平铺,无法使用css sprite。
目录说明:
思路:
        1、首先下载此方案所用到的js文件和透明gif  jquerypngfix.zip (2.7 kb, 下载次数: 3697) 
        2、找到js文件中找到blankgif: 'images/blank.gif',将路径修改为相对于html文件的位置 (不相对于css或js文件!)
        3、由于此js只有使用ie6时才有用,所以为了让我们的页面更加高效的执行,我们可以将上方代码修改如下,只有ie6的时候才调用执行此javascript:
优点:
        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伪类也可以很好的解决。
目录说明:
思路:
        1、首先下载此方案所用到的文件,  dd_belatedpng.zip (3.76 kb, 下载次数: 4610) 
        2、引入刚下载的js文件,同样由于此js只有使用ie6时才有用,所以为了让我们的页面更加高效的执行,我们可以将上方代码修改如下,只有ie6的时候才调用执行此javascript:
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文件或者写两个
方案8 - evpng解决方案:
介绍:此方案与第七种方案差不多,使用方法也如出一辙,效果也非常不错。
目录说明:
思路:
        1、首先下载此方案所用到的文件,  evpng.zip (3.39 kb, 下载次数: 2843) 
        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入口
其它类似信息

推荐信息