关于IE背景图片显示100%(背景图片自动伸缩 自适应)

项目中header中有个PNG透明背景图片,图片原图比header大很多,在chrome和ff中直接平铺刚好能铺满整个header区域,

多出来的不显示,但在IE中会显示整个PNG图片的尺寸,导致撑大变形。后来在网上找到一段关于IE背景图片100%显示的帖子,

找到解决方法是:

filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='1.jpg',sizingMethod='scale');

加上以上代码完美解决!

 

转载帖子原文:

由于W3C准备中,背景图片并不支持伸缩功能。所以在IE和FF这两大浏览器中会有一些区别

在FF中的方法可谓简单,只需要用background-size则可以控制其随容器的大小而自动伸缩

例子如下

.picLUp
{

 background:url(logo.png) no-repeat;
 width:100%;height:40%;
 background-size:100% 100%;
}

 

在这样的CSS控制之下则可以在FF中达到背景图片随父容器大小而自动变化,达到填充效果

但是在IE之下,你会发现上面的CSS控制会很不理想,它并不会因为你有了background-size:100% 100%;而

自动缩放,图片原本怎么样就怎么样显示,如果容器比图片小,则只能显示图上的一部分

那么要达到这个效果,则需要用到一些特别的东西

AlphaImageLoader兼容性:IE5.5+

语法:

filter : progid:DXImageTransform.Microsoft.AlphaImageLoader ( enabled=bEnabled , sizingMethod=sSize , src=sURL )

属性:

enabled : 
可选项。布尔值(Boolean)。设置或检索滤镜是否激活。true | false

true 
: 
默认值。滤镜激活。

false 
: 
滤镜被禁止。

sizingMethod 
: 
可选项。字符串(String)。设置或检索滤镜作用的对象的图片在对象容器边界内的显示方式。

crop 
: 
剪切图片以适应对象尺寸。

image 
: 
默认值。增大或减小对象的尺寸边界以适应图片的尺寸。

scale 
: 
缩放图片以适应对象的尺寸边界。

src 
: 
必选项。字符串(String)。使用绝对或相对 url 地址指定背景图像。假如忽略此参数,滤镜将不会作用。

特性:

Enabled 
: 
可读写。布尔值(Boolean)。参阅 enabled 属性。

sizingMethod 
: 
可读写。字符串(String)。参阅 sizingMethod 属性。

src 
: 
可读写。字符串(String)。参阅 src 属性。

说明:

在对象容器边界内,在对象的背景和内容之间显示一张图片。并提供对此图片的剪切和改变尺寸的操作。如果载入的是PNG(Portable Network Graphics)格式,则0%-100%的透明度也被提供。
PNG(Portable Network Graphics)格式的图片的透明度不妨碍你选择文本。也就是说,你可以选择显示在PNG(Portable Network Graphics)格式的图片完全透明区域后面的内容。

 

示例

.hello{
width:10%;
height:50%;
position:absolute;
filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='1.jpg',sizingMethod='scale');}

}

  

posted @ 2012-12-14 11:33  上善若水.  阅读(8966)  评论(0编辑  收藏  举报