PNG图片透明 IE6 解决方法
原文发布时间为:2009-11-18 —— 来源于本人的百度文章 [由搬家工具导入]
png透明解决办法
第1 种方法:定义一个样式,给某个div应用这个样式后,div的透明png背景图片自动透明了。(注意两处图片的路径写法不一样,本例中,icon_home.png图片与html文件在相同目录)。
样式定义的顺序很重要!
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
            <html xmlns="http://www.w3.org/1999/xhtml">
            <head>
            <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
            <title>http://hi.baidu.com/handboy</title>
            <style type="text/css">
            <!--
            .qq {
            height: 90px;
            width: 90px;
            background-image: url(icon_home.png)!important;/* IE6 FF IE7 三种浏览器均认识*/
            background-repeat: no-repeat;
_filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='icon_home.png'); /* 仅IE6 */
            _ background-image: none; /*仅 IE6 */
            }
            -->
            </style>
            </head>
<body>
<div class="qq"></div>
</body>
            </html>
第 2 种方法: 给img定义样式,页面上所有透明png即自动透明了。(这方法只对直接插入的图片有效,对背景图无效)注意,要准备一个透明的小图片transparent.gif,大小不限。必须放在和html相同的目录
            请勿大量使用,否则会导致页面打开很慢!!!)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
            <html xmlns="http://www.w3.org/1999/xhtml">
            <head>
            <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
            <title>无标题文档</title>
            <style type="text/css">
            .mypng img {
            azimuth: expression(
            this.pngSet?this.pngSet=true:(this.nodeName == "IMG" && this.src.toLowerCase().indexOf('.png')>-1?(this.runtimeStyle.backgroundImage = "none",
            this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.src + "', sizingMethod='image')",
            this.src = "transparent.gif"):(this.origBg = this.origBg? this.origBg :this.currentStyle.backgroundImage.toString().replace('url("','').replace('")',''),
            this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.origBg + "', sizingMethod='crop')",
            this.runtimeStyle.backgroundImage = "none")),this.pngSet=true);
            }
</style>
            </head>
<body>
            换成你的png图片
            <div class="mypng">
            <img src="icon_face_07.png" width="30" height="30" />
            <img src="icon_face_10.png" width="30" height="30" />
            <img src="icon_face_08.png" width="30" height="30" />
            </div>
            </body>
            </html>
第 3 种方法:用JS实现,加上一段js代码后,所有插入的透明png自动透明了.(注意,这方法也是只对直接插入的图片有效,对背景图无效)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
            <html xmlns="http://www.w3.org/1999/xhtml">
            <head>
            <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
            <title>无标题文档</title>
            <script language="JavaScript"> 
            function correctPNG() // correctly handle PNG transparency in Win IE 5.5 & 6. 
            { 
                 var arVersion = navigator.appVersion.split("MSIE") 
                 var version = parseFloat(arVersion[1]) 
                 if ((version >= 5.5) && (document.body.filters)) 
                 { 
                    for(var j=0; j<document.images.length; j++) 
                    { 
                       var img = document.images[j] 
                       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 
                          j = j-1 
                       } 
                    } 
                 }      
            } 
            window.attachEvent("onload", correctPNG); 
            </script>
            <style type="text/css">
            <!--
            body {
            background-color: #9999CC;
            }
            -->
            </style></head>
<body>
            把图片换成你自己的图片
            <img src="img/icon_face_03.png" width="30" height="30" /><!--把图片换成你自己的图片 -->
            <img src="img/icon_face_05.png" width="30" height="30" />
            <img src="img/menu_title_over.png" width="130" height="36" />
            </body>
            </html>    
方法四
<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>
用法如下:
            <img src="logo.png" width="328" height="325" border="0" onload="fixPNG(this)" />
PNG图片透明 IE6 解决方法的更多相关文章
- PIL在windwos系统下Image.show无法显示图片问题的解决方法
		环境:1.win7 64位 2.python 2.7.8 3.PIL-1.1.7.win32-py2.7 在运行一下例子时候出现问题: #-*-coding:utf-8-*- __author__ = ... 
- dedecms织梦手机端文章内容页图片不能自适应解决方法
		dedecms织梦手机端文章内容页图片不能自适应解决方法: 方法一修改手机端文章页模板代码: 找到并打开手机端的文章内容页模板,将里面的{dede:field.body/}标签修改一下,改为如下的标签 ... 
- ie6 png 透明的解决方法,大网站都在用
		今天解决png图片在IE6下的背景透明问题,找到了一个好方法.之前的解决方案会造成错位,使页面变形.现把这个方法公布如下,本人亲测可以正常使用,如果你在使用中出现问题,请看实例中的说明(英文不精的童鞋 ... 
- C# Winform控件对透明图片重叠时导致图片不透明的解决方法(转)
		在Winform中如果将一个透明图片放在窗体上能正常显示透明,但是如果将该图片放在另一个控件上会导致不能显示透明效果. 解决这种情况,可以采取在控件上使用GDI+绘画出透明图片. 这里我们就以一个pi ... 
- PNG24图片兼容IE6解决的方法
		非常多人都遇到一个问题:那就是PNG不能正常显示,比方: 网上试过的非常多办法都非常难实现.要嘛就是效果不好,那如今最好的办法就是直接调用JS插件,解决! 点击下载 如今说一下怎么用这个文件吧! 首先 ... 
- PNG兼容IE6解决方法
		虽然说现在早就不用ie6浏览器了,可以还是有一小部分还在使用 ,刚好公司也有要求~~~ <p> E6不兼容png图片,确实让网页的图片质量大大下降,为了兼容万恶的IE6,总结了下面几种方法 ... 
- Ecshop商品描述上传中文名图片无法显示解决方法
		在后台上传商品图片的时候,如果你选择一个中文名称的图片,那么上传后会产生乱码,导致图片显示不出来. 下面说一种解决办法:使用"年月日时分秒 + 6个随机字符"做为文件名,如 201 ... 
- Linux下CFD-Post视图透明的解决方法
		今天发生了一件很搞笑的事情,想用CFD-Post对计算结果做后处理,打开CFD-Post之后,背景居然是透明的,见图 做起后处理来完全看不清楚 下面是解决办法,很简单,步骤如下: 在终端中输入 sud ... 
- vue webpack打包后.css文件里面的背景图片路径错误解决方法
		资源相对引用路径 问题描述 一般情况下,通过webpack+vuecli默认打包的css.js等资源,路径都是绝对的. 但当部署到带有文件夹的项目中,这种绝对路径就会出现问题,因为把配置的static ... 
随机推荐
- 数据库sql语句的exists和in的区别
			性能变化的关键: #1 执行的先后顺序 谁是驱动表,谁先执行查询,谁后执行查询 #2 执行过程 exists的优点是:只要存在就返回了,这样的话很有可能不需要扫描整个表. in需要扫描完整个表,并 ... 
- java抓取12306火车余票信息
			最近在弄一个微信的公众帐号,涉及到火车票查询,之前用的网上找到的一个接口,但只能查到火车时刻表,12306又没有提供专门的查票的接口.今天突然想起自己直接去12306上查询,抓取查询返回的数据包,这样 ... 
- NopCommerce(Core)学习目录
			1.NopCommerce下载运行 2.登录及权限 3.日志 4.依赖注入使用autofac 5.插件实现 ... 
- 卸载Redhat 7自带的yum,安装并使用网易163源
			由于redhat的yum在线更新是收费的,如果没有注册的话不能使用,如果要使用,需将redhat的yum卸载后,安装CentOS yum工具,再配置其他源,以下为详细过程:删除redhat原有的yum ... 
- Vue插槽
			插槽内容 Vue实现一套内容分发的API, 这套API基于当前的web组件规范草案,将元素作为承载分发内容的出口. <navigation-link url="/profile&quo ... 
- Python 正则表达式 匹配次数
			管道可以匹配多个正则表达式中的一个 >>> >>> m=re.search(r'Batman|Tina Fey','Batman and Tina Fey')> ... 
- 2017 United Kingdom and Ireland Programming(Gym - 101606)
			题目很水.睡过了迟到了一个小时,到达战场一看,俩队友AC五个了.. 就只贴我补的几个吧. B - Breaking Biscuits Gym - 101606B 旋转卡壳模板题.然后敲错了. 代码是另 ... 
- 关于欧几里德算法(gcd)的证明
			求a,b的最大公约数我们经常用欧几里得算法解决,也称辗转相除法, 代码很简短, int gcd(int a,int b){ return (b==0)?a:gcd(b,a%b); } 但其中的道理却很 ... 
- Linux命令之---find
			命令简介 find明林用于查找目录下的文件,同时也可以调用其他命令执行相应的操作 命令格式 find pathname -options [-print -exec -ok ...] find [选项 ... 
- Diycode开源项目 磁盘图片缓存+自定义webViewClient+图片点击js方法
			1.磁盘图片缓存器DiskImageCache 1.1.这个类很多情况都可能用的到,耦合性很低,所以分开讲. 源代码: /* * Copyright 2017 GcsSloop * * License ... 
