首页 >

IE6兼容透明背景图片及解决方案【javascript】

web前端|js教程IE6兼容透明背景图片及解决方案【javascript】
ie6背景图片透明,ie6背景图透明,e6透明兼容
web前端-js教程
首先给大家展示效果图:
无线adb源码,mac vscode 更新,ubuntu lang,tomcat跟php,sqlite苹果手机版,蘑菇插件分享码,不是前端框架的是什么,爬虫培训骗局怎么举报,php 访问mysql,南明区seo,任务多网站源码,登录网页 文本框css,u站模板下载lzw
asp 点播 源码,vscode 主题创建,ubuntu getflv,tomcat本地很慢,sqlite数据库批量,wordpress赞踩插件,乾坤微前端框架使用方法,侏罗纪世界2中的爬虫,php 截取 url,苏州昆山seo费用,蓝色脚手架织梦企业网站模板,好看的网页导航代码,html网页页面模板代码下载lzw
JS代码:
字符串替换函数java源码,vscode运行vue项目指令,ubuntu输入法软件,tomcat 集群监控,tk sqlite,网页设计如何做半透明,网站远程数据库,服务器代维合同,wp插件,前端ssm框架,思维爬虫,php txt 换行,朋少seo,springboot稿件签发,滑动 标签,如何上传网站数据库,js网页广告特效代码,ecshop 发货列表模板,php后台新闻添加模板下载,html找回密码页面模板,仓储管理系统模板,pi算法程序lzw
$(function () {

//1、通过公共类

DD_belatedPNG.fix(".jpgFix,.jpgFix:hover");

//2、直接用选择器:类名,ID,标签

DD_belatedPNG.fix(".imgpng,img");});

html代码:

DD_belatedPNG实现IE6下的透明背景

1、通过公共类pngFix

window.onload = function () {DD_belatedPNG.fix(".jpgFix,.jpgFix:hover");}

2、直接用选择器:类名,ID,标签实现

DD_belatedPNG.fix(".imgpng,img");

css代码:

.contain { width: 1000px; height: 300px; margin: 0 auto; background: #fff; }.contain .con { width: 400px; float: left; }.contain h1 { font-size: 18px; color: #333; margin-bottom: 10px; }.contain h2 { font-size: 16px; color: #333; }.imgpng { width: 200px; height: 150px; background: url(/Content/IMG/Ie6.jpg); }
ie6中的透明图片不是透明显示的解决方案

一些图片存在着浏览器的兼容性,本身是透明的图片在ie6中却是不透明,比如:

在ie6中的效果

正常显示的效果

针对以上情况只需要在代码中最后加上下面这一段代码就可以解决了

function correctPNG(){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.cssTextif (img.align == "left") imgStyle = "float:left;" + imgStyleif (img.align == "right") imgStyle = "float:right;" + imgStyleif (img.parentElement.href) imgStyle = "cursor:hand;" + imgStylevar strNewHTML = ""img.outerHTML = strNewHTMLi = i-1}}}correctPNG();
IE6PNG透明解决方案

A、使用滤镜 代码:

 #pics {  background:url(../images/Logo.jpg)no-repeat;  /*以下为IE6设置PNG透明代码*/  _background:none;  _filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src="images/Logo.jpg" alt="IE6兼容透明背景图片及解决方案【javascript】" title="IE6兼容透明背景图片及解决方案【javascript】"); }
提示:如果需要使其支持链接的hover,那么需要在CSS中定义:cursor:pointer;使其呈现手型,否则将为默认的鼠标状态。

优点

1、绿色无插件;

2、效率高,速度快;

3、网速慢的时候,不会出现先灰底再透明的情况,支持远程图片;

4、支持Hover等伪类,但是得使用两张图片,网速慢的情况下,会导致第二张图片暂时无法显示,因为还没有完全载入;

缺点:

1、不支持平铺,虽然filter有sizingMethod=”scale”, 拉伸缩放模式,但是图片会变形,如果单纯的颜色或简单的渐变色还能横向平铺;

2、不支持Img标签;

3、不支持CSS Sprite;

使用情况:

1、当没有img引入png时可考虑;

2、当没有CSS Sprite需求时可考虑;

3、当没有平铺需求时候可考虑;

B、利用JS解决html中的img(插入在网页中的png图像)png背景灰问题

页面中插入一段js即可。原理同上,只是将img标签用标签替换掉,并且通过滤镜设置该标签的background。它会将所有插入的PNG都如此处理。

 function correctPNG() {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 = "";img.outerHTML = strNewHTML;i = i-1;}}}window.attachEvent("onload", correctPNG); ​
C、DD_belatedPNG.js文件

1、引入js文件,同样由于此js只有使用IE6时才有用,所以为了让我们的页面更加高效的执行,我们可以将上方代码修改如下,只有IE6的时候才调用执行此JavaScript:

2、调用函数,设置参数如下:


DD_belatedPNG.fix("#pngImg,#pics,#picsRepeat");

其中传入的参数为所使用png图片的标签的ID、类样式和标签名称,同样也可以按照下方这样来写


DD_belatedPNG.fix("#contentimg");

此方法则表示#content下的所有img标签透明

如果为链接和链接的hover设置透明,那么您按照下方这么来写,在部分版本里面可以不用加入:hover直接写选择器即可,但是为了保险,建议咱们还是加上:hover:


DD_belatedPNG.fix("#links,#link:hover");

写到这里并且您使用过jQuery或者CSSQuery类库,那么您一定熟悉上面的这种选择方法,总之就是,在CSS中您是如何选择的元素,那么在这个js函数(方法)中传入什么,只不过多个选择的时候,使用逗号隔开即可。

小技巧:如果页面中存在很多png,DD_belatedPNG.fix();函数的参数岂不是很长?我们可以使用这种写法:


DD_belatedPNG.fix(".jpgFix,.jpgFix:hover");

如果使用上述的写法,我们的html中只需要在相对应的标签上加入class="pngFix"就行了,如果有多个类样式,按照平时的多个类样式的写法即可class="abc cbc pngFix",

使用此方法的时候,我们每次都要加载两个js文件或者写两个标签才行,这样不太好,http请求会增多,那么我们可以打开DD_belatedPNG.js文件,在尾部加入如下代码

即可:

 window.onload= function() {  DD_belatedPNG.fix(".jpgFix,.jpgFix:hover"); }
这样我们只需要引入此JS,在需要透明的标签上加入class="pngFix"即可,简单 · 方便 · 快捷!

优点:

1、CSS代码无需任何修改,按照平时的思路来写即可;

2、无需配置;

3、没有多余的gif图片;

4、支持img;

5、支持平铺;

6、支持CSS Sprite;

7、支持Hover等伪类;

缺点:

1、额外加入了js文件(6.39k)和http请求,可以忽略不计;

2、当文件载入之前,会先暂时呈现灰底;

3、js文件过多的时候,可能会报错,导致js无法正常运行(这种情况极少出现,可以忽略不计);

以上就是本文讲述IE6兼容透明背景图片及解决方案的全部内容,希望对大家有所帮助。


  • 暂无相关文章