用 javascript 修复 IE 下 PNG 图片不能透明显示的方法

本文提供了一种使用JavaScript解决IE浏览器中PNG图片透明显示问题的方法。适用于IE5.5至6.0版本,通过修改图片标签实现正确透明效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

PNG 是可携式网络图像Portable Network Graphics这三个单词的第一个字母的缩写。她和 GIF 一样支持透明背景,但其对透明的处理质量远远大于 GIF,逐渐成为网页制作者非常喜欢的一种图片格式。令人无奈的是,IE 却不支持 PNG 图片的透明处理,本文介绍的方法就是针对这一问题的。

在需要的时候修复


用 javascript 修复 IE 下 PNG 图片不能透明显示的方法 – 示例

// 说明:修复 IE 下 PNG 图片不能透明显示的问题
// 整理:http://www.CodeBit.cn
 
function fixPNG(myImage)
{
     var arVersion = navigator.appVersion.split( "MSIE" );
     var version = parseFloat(arVersion[1]);
 
     if ((version >= 5.5) && (version < 7) && (document.body.filters))
     {
         var imgID = (myImage.id) ? "id='" + myImage.id + "' " : "" ;
         var imgClass = (myImage.className) ? "class='" + myImage.className + "' " : "" ;
         var imgTitle = (myImage.title) ? "title='" + myImage.title  + "' " : "title='" + myImage.alt + "' " ;
         var imgStyle = "display:inline-block;" + myImage.style.cssText;
         var strNewHTML = "<span " + imgID + imgClass + imgTitle
             + " style=\"" + "width:" + myImage.width
             + "px; height:" + myImage.height
             + "px;" + imgStyle + ";"
             + "filter:progid:DXImageTransform.Microsoft.AlphaImageLoader"
             + "(src=\'" + myImage.src + "\', sizingMethod='scale');\"></span>" ;
         myImage.outerHTML = strNewHTML;
     }
}

在页面中需要用到 PNG 图片的地方,添加

οnlοad="fixPNG(this)"

一次性修复页面上所有的 png

// 说明:用 javascript 修复 IE 下 PNG 图片不能透明显示的方法
// 整理:http://www.CodeBit.cn
 
/*
 
Correctly handle PNG transparency in Win IE 5.5 & 6.
http://homepage.ntlworld.com/bobosola. Updated 18-Jan-2006.
 
Use in <HEAD> with DEFER keyword wrapped in conditional comments:
<!--[if lt IE 7]>
<script defer type="text/javascript" src="pngfix.js"></script>
<![endif]-->
 
*/
 
var arVersion = navigator.appVersion.split( "MSIE" )
var version = parseFloat(arVersion[1])
 
if ((version >= 5.5) && (document.body.filters))
{
    for ( var i=0; i<document.images.length; i++)
    {
       var img = document.images[i]
       var imgName = img.src.toUpperCase()
       if (imgName.substring(imgName.length-3, imgName.length) == "PNG" )
       {
          var imgID = (img.id) ? "id='" + img.id + "' " : ""
          var imgClass = (img.className) ? "class='" + img.className + "' " : ""
          var imgTitle = (img.title) ? "title='" + img.title + "' " : "title='" + img.alt + "' "
          var imgStyle = "display:inline-block;" + img.style.cssText
          if (img.align == "left" ) imgStyle = "float:left;" + imgStyle
          if (img.align == "right" ) imgStyle = "float:right;" + imgStyle
          if (img.parentElement.href) imgStyle = "cursor:hand;" + imgStyle
          var strNewHTML = "<span " + imgID + imgClass + imgTitle
          + " style=\"" + "width:" + img.width + "px; height:" + img.height + "px;" + imgStyle + ";"
          + "filter:progid:DXImageTransform.Microsoft.AlphaImageLoader"
          + "(src=\'" + img.src + "\', sizingMethod='scale');\"></span>"
          img.outerHTML = strNewHTML
          i = i-1
       }
    }
}

将上面的代码另存为 js 文件,然后在页面中插入:

<!--[if lt IE 7]>
<script defer type="text/javascript" src="pngfix.js"></script>
<![endif]-->
因为 png 图片只有在 IE 中才会有不透明的问题,所以只需在用 IE 浏览时才加载代码,注意要在调用代码中加上 DEFER  关键词,这样会延迟代码执行时间。

它告诉浏览器Script段包含了无需立即执行的代码,并且,与SRC属性联合使用,它还可以使这些脚本在后台被下载,前台的内容则正常显示给用户。

请注意两点:

1、不要在defer型的脚本程序段中调用document.write命令,因为document.write将产生直接输出效果。

2、而且,不要在defer型脚本程序段中包括任何立即执行脚本要使用的全局变量或者函数。

转载:http://www.codebit.cn/javascript/fix-png.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值