PNG背景透明问题
2007-10-12 16:41
393 查看
方法一、通过 css 和 IE 专有属性 behavior 解决整站 png 背景透明问题
<style type="text/css">
<!--
img { behavior:url(/iepngfix.htc); }
-->
</style>
htc文件内容
<public:component>
<public:attach event="onpropertychange" onevent="doFix()" />
<script type="text/javascript">
// IE5.5+ PNG Alpha Fix v1.0RC3
// (c) 2004-2005 Angus Turnbull http://www.twinhelix.com
// This is licensed under the CC-GNU LGPL, version 2.1 or later.
// For details, see: http://creativecommons.org/licenses/LGPL/2.1/
// This must be a path to a blank image. That's all the configuration you need.
var blankImg = '/spacer.gif';
var f = 'DXImageTransform.Microsoft.AlphaImageLoader';
function filt(s,m)
{
if (filters[f])
{
filters[f].enabled = s ? true : false;
if (s) with (filters[f])
{
src = s;
sizingMethod = m;
}
}
else if (s)
{
style.filter = 'progid:'+f+'(src="'+s+'",sizingMethod="'+m+'")';
}
}
function doFix()
{
// Assume IE7 is OK
if (!/MSIE (5\.5|6\.)/.test(navigator.userAgent) || (event && !/(background|src)/.test(event.propertyName)))
{
return;
}
var bgImg = currentStyle.backgroundImage || style.backgroundImage;
if (tagName == 'IMG')
{
if ((/\.png$/i).test(src))
{
// this tests to see if the image has already been replaced once before
if (src.indexOf('?repurl=') == -1)
{
if (currentStyle.width == 'auto' && currentStyle.height == 'auto')
{
style.width = offsetWidth+'px';
}
filt(src,'scale');
src = blankImg+'?repurl='+src;
}
}
else if (src.indexOf(blankImg) < 0)
{
filt();
}
}
else if (bgImg && bgImg != 'none')
{
if (bgImg.match(/^url[("']+(.*\.png)[)"']+$/i))
{
var s = RegExp.$1;
if (currentStyle.width == 'auto' && currentStyle.height == 'auto')
{
style.width = offsetWidth+'px';
}
style.backgroundImage = 'none';
filt(s,'crop');
// IE link fix
for (var n=0;n<childNodes.length;n++)
{
if (childNodes
.style) { childNodes
.style.position = 'relative'};
}
}
else filt();
}
}
doFix();
</script>
</public:component>
方法二、通过 css ie滤镜解决
<style type="text/css">
<!--
.pngpic { filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='/pngpic.png',sizingMethod='crop'); }
-->
</style>
方法三、通过 javascript 和 css 滤镜解决 IE 整站 png 背景透明问题
<script type="text/javascript" language="javascript">
function enablePngImages() {
var imgArr = document.getElementsByTagName("IMG");
for(i=0; i<imgArr.length; i++){
if(imgArr[i].src.toLowerCase().lastIndexOf(".png") != -1){
imgArr[i].style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + imgArr[i].src + "', sizingMethod='auto')";
imgArr[i].src = "spacer.gif";
}
if(imgArr[i].currentStyle.backgroundImage.lastIndexOf(".png") != -1){
var img = imgArr[i].currentStyle.backgroundImage.substring(5,imgArr[i].currentStyle.backgroundImage.length-2);
imgArr[i].style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='"+img+"', sizingMethod='crop')";
imgArr[i].style.backgroundImage = "url(spacer.gif)";
}
}
}
function enableBgPngImages(bgElements){
for(i=0; i<bgElements.length; i++){
if(bgElements[i].currentStyle.backgroundImage.lastIndexOf(".png") != -1){
//alert(bgElements[i]);
var img = bgElements[i].currentStyle.backgroundImage.substring(5,bgElements[i].currentStyle.backgroundImage.length-2);
bgElements[i].style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='"+img+"', sizingMethod='crop')";
bgElements[i].style.backgroundImage = "url(spacer.gif)";
}
}
}
</script>
<img src="pngpic.png" alt="" border="0" />
<!--[if lt IE 7]>
<script type='text/javascript'>
var bgElements;
enablePngImages();
if(bgElements){
enableBgPngImages(bgElements);
}
</script>
<![endif]-->
<style type="text/css">
<!--
img { behavior:url(/iepngfix.htc); }
-->
</style>
htc文件内容
<public:component>
<public:attach event="onpropertychange" onevent="doFix()" />
<script type="text/javascript">
// IE5.5+ PNG Alpha Fix v1.0RC3
// (c) 2004-2005 Angus Turnbull http://www.twinhelix.com
// This is licensed under the CC-GNU LGPL, version 2.1 or later.
// For details, see: http://creativecommons.org/licenses/LGPL/2.1/
// This must be a path to a blank image. That's all the configuration you need.
var blankImg = '/spacer.gif';
var f = 'DXImageTransform.Microsoft.AlphaImageLoader';
function filt(s,m)
{
if (filters[f])
{
filters[f].enabled = s ? true : false;
if (s) with (filters[f])
{
src = s;
sizingMethod = m;
}
}
else if (s)
{
style.filter = 'progid:'+f+'(src="'+s+'",sizingMethod="'+m+'")';
}
}
function doFix()
{
// Assume IE7 is OK
if (!/MSIE (5\.5|6\.)/.test(navigator.userAgent) || (event && !/(background|src)/.test(event.propertyName)))
{
return;
}
var bgImg = currentStyle.backgroundImage || style.backgroundImage;
if (tagName == 'IMG')
{
if ((/\.png$/i).test(src))
{
// this tests to see if the image has already been replaced once before
if (src.indexOf('?repurl=') == -1)
{
if (currentStyle.width == 'auto' && currentStyle.height == 'auto')
{
style.width = offsetWidth+'px';
}
filt(src,'scale');
src = blankImg+'?repurl='+src;
}
}
else if (src.indexOf(blankImg) < 0)
{
filt();
}
}
else if (bgImg && bgImg != 'none')
{
if (bgImg.match(/^url[("']+(.*\.png)[)"']+$/i))
{
var s = RegExp.$1;
if (currentStyle.width == 'auto' && currentStyle.height == 'auto')
{
style.width = offsetWidth+'px';
}
style.backgroundImage = 'none';
filt(s,'crop');
// IE link fix
for (var n=0;n<childNodes.length;n++)
{
if (childNodes
.style) { childNodes
.style.position = 'relative'};
}
}
else filt();
}
}
doFix();
</script>
</public:component>
方法二、通过 css ie滤镜解决
<style type="text/css">
<!--
.pngpic { filter: progid:DXImageTransform.Microsoft.AlphaImageLoader(src='/pngpic.png',sizingMethod='crop'); }
-->
</style>
方法三、通过 javascript 和 css 滤镜解决 IE 整站 png 背景透明问题
<script type="text/javascript" language="javascript">
function enablePngImages() {
var imgArr = document.getElementsByTagName("IMG");
for(i=0; i<imgArr.length; i++){
if(imgArr[i].src.toLowerCase().lastIndexOf(".png") != -1){
imgArr[i].style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + imgArr[i].src + "', sizingMethod='auto')";
imgArr[i].src = "spacer.gif";
}
if(imgArr[i].currentStyle.backgroundImage.lastIndexOf(".png") != -1){
var img = imgArr[i].currentStyle.backgroundImage.substring(5,imgArr[i].currentStyle.backgroundImage.length-2);
imgArr[i].style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='"+img+"', sizingMethod='crop')";
imgArr[i].style.backgroundImage = "url(spacer.gif)";
}
}
}
function enableBgPngImages(bgElements){
for(i=0; i<bgElements.length; i++){
if(bgElements[i].currentStyle.backgroundImage.lastIndexOf(".png") != -1){
//alert(bgElements[i]);
var img = bgElements[i].currentStyle.backgroundImage.substring(5,bgElements[i].currentStyle.backgroundImage.length-2);
bgElements[i].style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='"+img+"', sizingMethod='crop')";
bgElements[i].style.backgroundImage = "url(spacer.gif)";
}
}
}
</script>
<img src="pngpic.png" alt="" border="0" />
<!--[if lt IE 7]>
<script type='text/javascript'>
var bgElements;
enablePngImages();
if(bgElements){
enableBgPngImages(bgElements);
}
</script>
<![endif]-->
相关文章推荐
- IE5.5和IE6.0中png背景透明问题
- IE6下png图片和背景图片透明问题解决方法
- [Javascript] 解决 IE6 中 png 图片背景不支持透明效果的问题
- 一次性解决png在i6下的透明问题(包括做为img和背景的两种情况)
- 处理IE6下PNG图片透明背景问题
- IE6下png背景不透明问题的综合拓展
- DD_belatedPNG.js解决透明PNG图片背景灰色问题(DD_belatedPNG.js下载)
- 使用JS插件解决IE6不支持PNG透明背景问题
- CodeIgniter中PNG图片处理背景不透明问题的解决办法
- IE6下png背景不透明问题的综合拓展
- 解决IE6下png图片文件背景不透明的问题
- 以Png图片在网页中背景透明问题展开谈png图片格式问题
- IE6下滤镜插入透明PNG背景,解决失焦问题
- CSS解决IE6下PNG图片背景不透明的问题
- jQuery解决IE6下PNG图片背景透明问题
- IE6下PNG背景透明的显示问题
- Android PNG透明渐变背景图片失真问题
- 解决ie6下png不透明,出现灰色背景的问题
- Gif合成透明PNG变成黑色背景GIF问题解决