18910140161

纯CSS控制背景图片自适应填充布局

2021-10-26 13:00:14

245

 

原文:http://www.uedsc.com/css-background-size-100.html

解决:

 

[html] view plain copy  
  1. html,body{height: ;width: ;margin:0;padding:0;}  
  2. body{  
  3.     background:url(bg-login.png)no-repeat;  
  4.     width:;  
  5.     height:;  
  6.     background-size: ;  
  7.     position:absolute;  
  8.     filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=\'bg-login.png\',sizingMethod=\'scale\');  
  9. }  



 

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

在Firefox中,只需要用background-size则可以控制其随容器的大小而自动伸缩

[html] view plain copy  
  1. picLUp{  
  2.     background:url(logo.png)no-repeat;  
  3.     width:;height:40%;  
  4.     background-size:;  
  5. }  


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

 

AlphaImageLoader

兼容性

 

IE5.5+

语法

[html] view plain copy  
  1. 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%-的透明度也被提供。

PNG(Portable Network Graphics)格式的图片的透明度不妨碍你选择文本。也就是说,你可以选择显示在PNG(Portable Network Graphics)格式的图片完全透明区域后面的内容。

[html] view plain copy  
  1. hello{  
  2.     width:10%;  
  3.     height:50%;  
  4.     position:absolute;  
  5.     filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=\'1.jpg\',sizingMethod=\'scale\');  
  6. }  


通过上面两种方法的介绍,我们就可以完美兼容所有的浏览器,使用CSS让背景图填充。

原文:http://www.uedsc.com/css-background-size-100.html

解决:

 

[html] view plain copy  
  1. html,body{height: ;width: ;margin:0;padding:0;}  
  2. body{  
  3.     background:url(bg-login.png)no-repeat;  
  4.     width:;  
  5.     height:;  
  6.     background-size: ;  
  7.     position:absolute;  
  8.     filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=\'bg-login.png\',sizingMethod=\'scale\');  
  9. }  



 

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

在Firefox中,只需要用background-size则可以控制其随容器的大小而自动伸缩

[html] view plain copy  
  1. picLUp{  
  2.     background:url(logo.png)no-repeat;  
  3.     width:;height:40%;  
  4.     background-size:;  
  5. }  


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

 

AlphaImageLoader

兼容性

 

IE5.5+

语法

[html] view plain copy  
  1. 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%-的透明度也被提供。

PNG(Portable Network Graphics)格式的图片的透明度不妨碍你选择文本。也就是说,你可以选择显示在PNG(Portable Network Graphics)格式的图片完全透明区域后面的内容。

[html] view plain copy  
  1. hello{  
  2.     width:10%;  
  3.     height:50%;  
  4.     position:absolute;  
  5.     filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src=\'1.jpg\',sizingMethod=\'scale\');  
  6. }  


通过上面两种方法的介绍,我们就可以完美兼容所有的浏览器,使用CSS让背景图填充。

相关文章
我们已经准备好了,你呢?
2024我们与您携手共赢,为您的企业形象保驾护航