众所周知IE6不支持透明的PNG图片,而PNG图片在Web设计方面表现力上,具有其它图形格式所达不到的效果,IE6这一致命缺陷极大地限制了Web设计的创意发挥。
虽然解决IE6的透明PNG的方法也很多,从使用IE特有的滤镜或是expression,再到javascript+透明 GIF替代.但是这些方法都有一个缺点,就是不支持CSS中backgrond-position与background-repeat属性。而使用DD_belatedPNG.js可完美的解决IE6下PNG图片透明问题,并且支持backgrond-position与background-repeat. 这是其他方法所不具备的,同时DD_belatedPNG还支持a:hover属性,以及<img>。
我们的网站就加入了DD_belatedPNG处理导航PNG透明图片,使其在不同浏览器下保持相同的外观。
DD_belatedPNG 官方网站:点此访问!
使用方法:1、首先下载JS文件:
| DD_belatedPNG_0.0.8a 未压缩版本 |
| DD_belatedPNG_0.0.8a 压缩版 |
之后在页面中引用代码:
- <!–[ifIE6]>
- <scripttype=text/javascriptsrc=下载下来的JS路径></script>
- <script>
- DD_belatedPNG.fix(‘CSS选择器,应用类型 ’);
- </script>
- <![endif]–>
引用函数是 DD_belatedPNG.fix() , 括号里分别填写应用PNG的CSS选择器(可使用ID选择器和类选择器)和应用类型(分为img 和 background 两种)。
如DD_belatedPNG.fix(‘#box-one, img ’) 或者 DD_belatedPNG.fix(‘.header, background ’) 等。
这些可以简写成 DD_belatedPNG.fix(‘#box-one, .header, img,background ’); 。
更多选择器的如 DD_belatedPNG.fix(‘#box-one, .header,#footer,.box-two a:hover, img,background ’); 等等。
另外,为解决IE6下背景图闪烁,可以在页面中添加如下脚本:
- <!–[ifIE6]>
- <scripttype=text/javascript>
- //<![CDATA[
- if((window.navigator.appName.toUpperCase().indexOf(MICROSOFT)>=0)&&(document.execCommand))
- try{
- document.execCommand(BackgroundImageCache,false,true);
- }
- catch(e){}
- //]]>
- </script>
- <![endif]–>