如何通过CSS拉伸背景图像/图像来填充容器?

时间:2012-09-26 12:38:36

标签: html css svg background-image

我有一个比例矢量图像,我希望它填充一个容器。关于SO有几个这样的问题,尽管它们有点老了。例如。 Stretch and scale CSS background

但是,当我尝试实施此类解决方案时,结果令人失望。

例如:

    body  {

    margin: 0; 
    padding: 0;
    text-align: center; 
    color: #000;
    background-color: #000
    font-family: Verdana, Arial, Helvetica, sans-serif;
    font-size: 100%;

}

...

.twoColLiqLtHdr #container {
    width: 80%;
    margin: 0 auto; 
    border: 2px solid #000000;
    text-align: left; 
    background-color: #003;
    background-image: url('background_image.svg'); 
    /*background-position: 80% 80%; */

  background-repeat: no-repeat; 
    color: #000;
    font-family: "Times", cursive;


    background-attachment:fixed;
    min-height:100%;
    /*top: 0;
    left: 0; */



} 

我尝试了各种各样的安排但是我不能在没有留下空白区域的情况下伸展(重复是成功的,但看起来很糟糕)。

然而,由于我正在使用svg我可能以错误的方式接近这个,我应该在html中使用svg xmlns标签吗? (P.S.我知道IE8绝对无法处理svgs)

2 个答案:

答案 0 :(得分:17)

你试过吗

background-size:cover;

检查一些examples

我遇到了webkit,background-size:cover和SVG背景图片的问题。我解决了它添加

-webkit-background-origin:border;

答案 1 :(得分:11)

您可能需要将preserveAspectRatio =“none”添加为SVG图像本身中外部<svg>元素的属性。

如果您不想修改图像文件,可以尝试

background-image:url('background_image.svg#svgView(preserveAspectRatio(none))');

Firefox 15也支持这种功能,也可能支持其他UA。