JavaScript(JS)以调用的方式实现IE6浏览器PNG图片透明

上文说到《JavaScript(JS)实现IE6浏览器PNG图片透明》,这里提供另一种调用形式。(注意,这方法只对直接插入的图片有效,对背景图无效)。该方法针对个别需要实现透明效果的png图做单独设置。

以下代码插入网页头部:

<script language=”javascript”>
// 修复 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;
} }
window.onload=function(){
document.getElementById(“top”).style.height=screen.height/5+”px”;

}//
</script>

以下是<body>中的内容:

<img src=”logo.png” width=”328″ height=”325″ border=”0″ onload=”fixPNG(this)” />

推荐阅读:《DIV+CSS解决IE6浏览器PNG背景图不透明