您的位置:首页 > Web前端 > CSS

CSS背景图片自适应、全屏、填充、拉伸

2018-01-08 11:55 405 查看
方法一、
js控制:

方法二、
全浏览器兼容:

.bg{  
background:url(http://wyz.67ge.com/wp-content/uploads/qzlogo.jpg);  
filter:"progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='scale')";  
-moz-background-size:100% 100%;  
    background-size:100% 100%;  
}

总结:
做响应式布局的时候,如果有背景图,我们当然希望他能够全屏100%显示,这样显得页面非常的爆满,不过这又出现了一个问题,图片的尺寸多大合适呢,现在的浏览器分辨率参差不齐,对于Firefox等高级的浏览器,使用
Background-size
设置为
100%
即可,而IE浏览器就需要不同设置。

背景100%填充

在Firefox中,只需要用
background-size
则可以控制其随容器的大小而自动伸缩
.picLUp{
background:url(logo.png) no-repeat;
width:100%;
height:40%;
background-size:100% 100%;
}
在这样的CSS控制之下,则可以在Firefox中达到背景图片随父容器大小而自动变化,达到填充效果,图片会被拉伸填充,这并不是我们想要的效果,那么我们可以不设置
100%
参数,而是使用
cover
参数。
background-size:cover
设置cover参数以后,背景图会按比例缩放填充满整个背景。

针对IE浏览器

但是在IE之下,你会发现上面的CSS控制会很不理想,它并不会因为你有了
background-size:100% 100%;
而自动缩放,图片原本怎么样就怎么样显示,如果容器比图片小,则只能显示图上的一部分,那么要达到这个效果,则需要使用IE特有的滤镜。

AlphaImageLoader

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');
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: