- 浏览: 149987 次
- 性别:
- 来自: 福建
文章分类
最新评论
-
caibinghong:
Ahua772 写道非常好,谢谢了,但是运行的图片怎么没有加载 ...
用于WebKit的CSS诀窍 -
Ahua772:
非常好,谢谢了,但是运行的图片怎么没有加载出来呢
用于WebKit的CSS诀窍 -
caibinghong:
呃是一个方法,现在改过来了,当时考的时候没有改!现在最底层是i ...
关于innerHTML 赋值问题 -
jayrao5566:
js的正确写法不是 .innerHTML = '<op ...
关于innerHTML 赋值问题 -
caibinghong:
在JQ与EXT里都解决的挺好的。http://caibingh ...
关于innerHTML 赋值问题
方案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, 下载次数: 117)
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标签,对背景图片无效。
目录说明:
思路:
1、首先下载透明的图片文件 blank.zip (707 Bytes, 下载次数: 114)
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, 下载次数: 148)
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。
目录说明:
思路:
1、首先下载此方案所用到的js文件和透明gif jQueryPngFix.zip (2.7 KB, 下载次数: 158)
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伪类也可以很好的解决。
目录说明:
思路:
1、首先下载此方案所用到的文件, DD_belatedPNG.zip (3.76 KB, 下载次数: 274)
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解决方案:
介绍:此方案与第七种方案差不多,使用方法也如出一辙,效果也非常不错。
目录说明:
思路:
1、首先下载此方案所用到的文件, EvPng.zip (3.39 KB, 下载次数: 144)
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入口
发表评论
-
怪异模式(Quirks Mode)对 HTML 页面的影响
2015-02-02 11:49 1014怪异模式(Quirks Mode) ... -
强制不使用“兼容性视图”的HTML代码
2015-02-02 11:04 692强制不使用“兼容性视图”的HTML代码 在IE8浏览器以后 ... -
web前端新入培训
2014-08-18 09:43 760新人培训计划 第一周html+css 1.从零开 ... -
样式优先级
2014-07-10 11:53 531从上到下执行原则 样式优先级: 高到底 1~ ... -
IE对CSS样式表的限制和解决方案
2014-05-27 17:19 631HTML文档与CSS的关联常见有4种方式: 使用li ... -
定义文档兼容性,让IE按指定的版本解析我们的页面
2013-10-19 11:00 882使用文档兼容性的方法比较容易,就是在我们要反馈给客户端的HT ... -
CSS3 icon font完全指南
2013-10-10 11:29 670大家都知道现在各个浏览器都支持CSS3的自定义字体(@fon ... -
css ie6 下的png
2013-06-28 18:33 716.classPng{ position: absolute; ... -
<meta http-equiv="X-UA-Compatible" content="IE=7" />意思是将IE8用IE7进行渲染,使网页在IE8下正常显示
2013-06-26 14:54 900<meta http-equiv="X-UA ... -
css 将图片进行编码,然后存在文档中,减少请求数
2013-03-29 15:07 636background-image: url(data:ima ... -
响应式布局这件小事
2013-02-28 11:49 860讲到响应式布局, 相 ... -
CSS 在IE6, IE7 和IE8中的差别
2012-11-27 16:48 2199选择器与继承 伪类与伪元素 属性支持 其它各种技 ... -
移动端开发小结
2012-05-17 11:31 10761.viewport viewport就是除去所有工具 ... -
CSS3动画库,很棒哦
2012-05-17 11:30 787官网地址Animate CSS官网地址 Github地 ... -
IOS下Safari渲染Transition时页面闪动Bug
2012-05-17 11:30 5947http://classjs.com/category/tec ... -
移动平台WEB前端开发技巧汇总
2012-05-17 11:29 0原名《移动平台3G手机网站前端开发布局技巧汇总》,由武方 ... -
91uu浮云【桌面webapp块的实现方案】
2012-05-02 16:43 1118上一节说到这个简单类似网络收藏夹的webos,那么我们要怎么配 ... -
91uu浮云【排版布局】
2012-05-02 12:43 1320上一篇 91uu浮云【简介】只是很简单的贴图出来跟站点出 ... -
css透明度
2012-05-01 22:27 905filter:alpha(opacity=50); - ... -
浮动引起的行高丢失(float)
2012-05-01 22:16 1039浮动引起的行高丢失(float) 以下给出决解方案 ...
相关推荐
在互联网的早期,Internet Explorer 6(简称IE6)是主导浏览器之一,但它存在许多兼容性问题,其中就包括对PNG(Portable Network Graphics)图像格式的支持。PNG是一种流行且功能强大的位图格式,尤其适用于透明...
在IT行业中,尤其是在...总之,iepngfix是针对IE6浏览器PNG透明问题的一种解决方案,通过JavaScript技术实现对PNG图片的透明度支持。虽然如今已不再主流,但在过去,它为许多开发者提供了应对旧浏览器挑战的有效途径。
在早期的网页设计中,IE6(Internet Explorer 6)浏览器因其对PNG图像格式透明度的支持问题而给开发者带来了困扰。PNG(Portable Network Graphics)是一种常见的图像格式,它支持24位真彩色以及Alpha通道透明度,但...
在代码的开始处直接有介绍如何使用,这个不需要其他任何多余的处理,而且还可以解决背景定位情况下,IE6下的PNG修复问题,可以说是目前解决PNG问题最为完美的处理方式
在互联网的早期,Internet Explorer 6 (简称IE6) 是一款广泛使用的浏览器,但随着Web技术的发展,它逐渐暴露出许多兼容性问题,其中最著名的就是PNG(Portable Network Graphics)图像格式的透明度支持问题。...
标题“IE6 PNG 透明处理方法”涉及到的是一个在网页设计中常见的问题,尤其是在与旧版Internet Explorer(尤其是IE6)兼容性相关的上下文中。在IE6中,PNG图像格式的透明度支持并不完善,导致许多设计师在创建具有半...
在IT领域,尤其是在网页设计和开发中,"IE6 png背景图片透明"是一个经典的问题,因为Internet Explorer 6(简称IE6)对于PNG格式图像的透明处理与其他现代浏览器存在显著差异。PNG是一种流行的图像格式,支持24位...
在早期的网页设计中,IE6(Internet Explorer 6)作为主流浏览器,其对PNG(Portable Network Graphics)图像格式的支持存在显著的问题,尤其是对于PNG-24格式的图像,它无法正确显示背景透明或者半透明效果。...
IE6png格式兼容,格式兼容希望可以帮助你
虽然iepngfix.htc在某些情况下可以部分解决PNG透明问题,但确实存在一些局限性,比如无法平铺、定位困难,以及在添加了超链接的PNG图像上,点击区域可能无法正常工作。 DD_belatedPNG的优势在于,它不仅解决了iepng...
除了CSS滤镜,还可以使用JavaScript库如DD_belatedPNG或PNGFix等,它们专门用于解决IE6的PNG透明问题。这些库通过JavaScript动态添加滤镜,同时兼容PNG-8和PNG-24格式。 例如,DD_belatedPNG库的使用方法: 1. ...
2. **IE6的PNG透明问题**:IE6不支持PNG24的阿尔法透明,导致图片背景显示为黑色或不透明。对于PNG8,只有256色以下的颜色和单色透明可以正常显示,复杂的透明效果无法实现。 3. **JavaScript解决方案**:为了克服...
在IT行业中,尤其是在网页设计和开发领域,"解决ie6下png图片背景问题"是一个经典且重要的主题。Internet Explorer 6(简称IE6)是微软公司早期推出的一款浏览器,由于其对PNG(Portable Network Graphics)图像格式...
调用方法: <!--[if lt IE 7]> // less than ie 7 ... ie_png.fix('.png, .menu ul li a span'); // 第二个参数为含有png的标签id(css) ie_png.fix('.png, .logo span'); // 有png的都加上去 <![endif]-->
在早期的Internet Explorer 6(简称IE6)浏览器中,PNG格式的图片存在一个众所周知的问题:它不支持24位PNG图像的透明效果。这个问题给网页设计师带来了许多困扰,因为PNG格式的透明特性在其他现代浏览器中是被广泛...
在互联网的早期,Internet Explorer 6 (IE6) 是广泛使用的浏览器之一,但它存在许多兼容性问题,其中就包括PNG图片透明度的问题。PNG(Portable Network Graphics)是一种支持透明度的图像格式,但在IE6中,它无法...
在早期的网页设计中,IE6(Internet Explorer 6)浏览器对PNG图像格式的透明支持是有限的,尤其是对于PNG-24格式的图像,它只支持简单的索引颜色透明,而对于真彩色的PNG图像则无法实现透明效果。这给网页设计师带来...
在IE6浏览器中,PNG(Portable Network Graphics)格式的图片无法正常显示透明效果,这是一个长期困扰前端开发者的著名问题。由于IE6不支持PNG-24格式的 Alpha 透明通道,导致图片背景出现黑色或者半透明遮罩。为了...
### 解决IE6 PNG透明问题的方法 在网页设计与开发领域中,Internet Explorer 6(简称 IE6)因其对部分CSS特性和图像处理的支持不足而成为不少开发者头疼的问题之一,尤其是PNG透明效果的支持。本文将详细介绍两种...