CSS背景图片实现自适应、全屏、填充与拉伸的方法

  方法一、

  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=http://www.jb51.net/css/sURL )

  属性

  特性

  说明

  在对象容器边界内,在对象的背景和内容之间显示一张图片。并提供对此图片的剪切和改变尺寸的操作。如果载入的是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');

  }

  总结

  以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。