IE浏览器PNG透明图片的正确显示 [ 网站地图 ]

发表于:2009-12-14 浏览:41 作者: 来源:互联网

关键字:PNG透明图片,IE浏览器

描述:png图片有很好的品质。阴影效果也不会有杂边,很流畅。如果插入网页的话可以给网站内容增色不少!更重要的是在不增加图片容量大小的情况下NOBRoncontextmenu="returnfalse"id=clickeyekey1over=$cE.s(event

png图片有很好的品质。阴影效果也不会有杂边,很流畅。如果插入网页的话可以给网站内容增色不少!更重要的是在不增加图片容量大小的情况下提高了页面的图片的质量。对于有复杂背景,如:在有颜色过度背景上插入不规则边框的图片带来极大很便利!

  但目前IE中对于插入的透明背景的.png的图片是不能正常显示的。IE会自动给".png"格式的图片加个灰色背景。

  解决这个的方法是增加javascript。具体方法如下:

  把下面的代码放在head区就可以解决问题了。

以下是引用片段:
<scriptlanguage="javascript">
functioncorrectPNG() 
{
for(vari=0;i<document.images.length;i++)
{
 varimg=document.images[i]
 varimgName=img.src.toUpperCase()
 if(imgName.substring(imgName.length-3,imgName.length)=="PNG")
 {
 varimgID=(img.id)?"id=‘"+img.id+"‘":""
 varimgClass=(img.className)?"class=‘"+img.className+"‘":""
 varimgTitle=(img.title)?"title=‘"+img.title+"‘":"title=‘"+img.alt+"‘"
 varimgStyle="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 
 varstrNewHTML="<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
 }
}
}
window.attachEvent("onload",correctPNG);
</script>

  也可以把这段代码单独加在一张图片上:

以下是引用片段:
<span
style="filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=‘male.png‘,sizingMethod=‘scale‘);"></span>


站长资讯网 做中国最丰富的资讯网站 沪ICP备05004089号