msgbartop
世界上没有老实人,所谓的老实人是用来欺骗像我这样老实的人!
msgbarbottom

08 9月 12 IE浏览器下PNG透明的解决方案

2012年9月08日发表于Int.Ru | 共有:4 人评论

网上一直在讲PNG在IE6下不能透明。

今天午夜客做今生有约婚纱摄影的效果时就刚才要用到PNG图片透明的效果。

在网上找了一下解决方案,一般就是用JS比较简单了。

 

 在需要的时候修复

 

// 说明:修复 IE 下 PNG 图片不能透明显示的问题

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 图片的地方,添加

onload="fixPNG(this)"

如:

<img src="apple.png" alt="PNG" style="border:1px solid #999;" onload="fixPNG(this)" />


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

 

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

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]–>


原文地址:http://www.codebit.cn/javascript/fix-png.html/comment-page-1

PS:ie浏览器并不是不支持png格式,而是只支持8位的PNG图片!

                                

Reader's Comments

  1.    

    早已不用IE6,现在用IE8

    Reply to this comment
  2.    

    彻底没空间用了,请推荐一个php空间吧,空间和流量不需要太大,不能绑米也行,或者干脆你给我开一个吧

    Reply to this comment
  3.    

    我就是用的这个JS。

    Reply to this comment

您的留言

*