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

合集下载
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

使用javascript修复IE不能显示PNG图片透明背景的方法
摘要: PNG 是可携式网络图像Portable Network Graphics这三个单词的第一个字母的缩写。

她和GIF 一样支持透明背景,但其对透明的处理质量远远大于GIF,逐渐成为网页制作者非常喜欢的一种图片格式。

令人无奈的是,IE7前的版本却不支持PNG图片的透明背景处理,本文介绍的方法就是针对这一问题的。

Javascript:
// 说明:修复IE 下PNG 图片不能透明显示的问题
// 整理:
function fixPNG(myImage)
{
var arV ersion = navigator.appV ersion.split("MSIE");
var version = parseFloat(arV ersion[1]);
if ((version >= 5.5) && (version < 7) && (document.body.filters))
{
var imgID = (myImage.id) ? "id='" + myImage.id + "' " : "";
var imgClass = (myImage.className) ? " " : "";
var imgTitle = (myImage.title) ? "title='" + myImage.title + "' " : "title='" + myImage.alt + "' ";
var imgStyle = "display:inline-block;" + myImage.style.cssT ext;
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;
}
}
将上面的代码另存为js 文件,然后在页面中插入:
<!--[if lt IE 7]>
<script defer type="text/javascript" src="pngfix.js"></script>
<![endif]-->
因为png 图片只有在IE 中才会有不透明的问题,所以只需在用IE 浏览时才加载代码,注意要在调用代码中加上DEFER 关键词,这样会延迟代码执行时间。

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

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

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

在页面中需要用到PNG 图片的地方,添加
onload="fixPNG(this)"
如:
<img src="apple.png" alt="PNG" style="border:1px solid #999;" onload="fixPNG(this)" />。

相关文档
最新文档