具有SVG背景的DIV不会完全覆盖父级

时间:2018-07-26 15:32:35

标签: html css svg

因此,请检查以下代码,其中包含一个带有banner的父div和一个子div,该子div的内部应为SVG“覆盖”背景。您会看到覆盖层没有完全覆盖父对象,左右两侧之间有一个小缝隙。

.HeroImage {
     position: relative;
     width: 934px;
}
.HeroImage-Arc {
     position: absolute;
     width: 100%;
     height: 100%;
     background: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440.5 82'%3E%3Cg%3E%3Cg%3E%3Cpath d='M1440.5,0q-360,82-720,82T.5,0L0,81.5H1440Z' style='fill:%23fff'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") center bottom no-repeat;
     top: 0;
}
<section class="HeroImage">
  <img src="https://cdn.esigns.com/pub-data/prod/imagebox/9/887/Free-Product-Samples_Imagebox_Landing-Page-R.png">
  <div class="HeroImage-Arc"></div>
</section>

但是,下面的第二个代码示例将SVG替换为PNG,并且效果很好。

.HeroImage {
     position: relative;
     width: 934px;
}
.HeroImage-Arc {
     position: absolute;
     width: 100%;
     height: 100%;
     background: url('') center bottom no-repeat;
     top: 0;
}
<section class="HeroImage">
  <img src="https://cdn.esigns.com/pub-data/prod/imagebox/9/887/Free-Product-Samples_Imagebox_Landing-Page-R.png">
  <div class="HeroImage-Arc"></div>
</section>

显而易见的解决方案是使用PNG版本。但是,这是一个主要是学术性的问题-我想弄清楚为什么SVG版本无法正常工作-但它也很实用,因为给定图像的SVG版本通常会小得多,例如此处。 >

2 个答案:

答案 0 :(得分:2)

原因是纵横比不兼容。

您的SVG的纵横比(从viewBox中查看)为:

1440.5/82 ~= 17.5671

当尝试将其缩小到div的宽度(934像素)时,其计算得出的大小为:

width:  934
height: 934 / (1440.5 / 82) ~= 53.1677 px 

将四舍五入为53,并将SVG渲染为934px x 53px的中间位图

但是SVG viewBox再次发挥作用,因为它希望在渲染SVG时保持正确的宽高比。因此,由于渲染的高度小于53.167像素,因此宽度也是如此。最终将约为(934 *(53 / 53.1677))〜= 931px。

您可以通过以下方式缓解这些问题:

  1. 使用舍入为整个单位的viewBox和路径坐标
  2. 指定不会导致宽度缩小到931的background-size934px 54px

.HeroImage {
     position: relative;
     width: 934px;
}
.HeroImage-Arc {
     position: absolute;
     width: 100%;
     height: 100%;
     background: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 82'%3E%3Cg%3E%3Cg%3E%3Cpath d='M1440,0q-360,82-720,82T0,0L0,82H1440Z' style='fill:%23fff'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") center bottom no-repeat;
     top: 0;
     background-size: 934px 54px;
}
<section class="HeroImage">
  <img src="https://cdn.esigns.com/pub-data/prod/imagebox/9/887/Free-Product-Samples_Imagebox_Landing-Page-R.png">
  <div class="HeroImage-Arc"></div>
</section>

这似乎可以在Firefox上完美运行,但是在Chrome浏览器的右侧仍然有一个条。可能是由于某种舍入误差。

最简单,最简单的解决方法是让您的路径在viewBox之外绘制几个像素,以便始终将路径绘制到至少外部边界。

例如,让我们使路径从-2到1442,而不是从0到1440。

.HeroImage {
     position: relative;
     width: 934px;
}
.HeroImage-Arc {
     position: absolute;
     width: 100%;
     height: 100%;
     background: url("data:image/svg+xml;charset=utf8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 1440 82'%3E%3Cg%3E%3Cg%3E%3Cpath d='M1442,0q-360,82-720,82T-2,0L0,82H1442Z' style='fill:%23fff'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E") center bottom no-repeat;
     top: 0;
     background-size: 934px 54px;
}
<section class="HeroImage">
  <img src="https://cdn.esigns.com/pub-data/prod/imagebox/9/887/Free-Product-Samples_Imagebox_Landing-Page-R.png">
  <div class="HeroImage-Arc"></div>
</section>

答案 1 :(得分:1)

您可以使用svg本身代替div.HeroImage-Arc

.HeroImage {
     position: relative;
     width: 934px;
}
svg {
     position: absolute;
     width: 100%;
     bottom: 0;
}
<section class="HeroImage">
  <img src="https://cdn.esigns.com/pub-data/prod/imagebox/9/887/Free-Product-Samples_Imagebox_Landing-Page-R.png">
  <svg viewBox="0 0 1440.5 82"><path fill="#fff" d="M1440.5 0q-360 82-720 82T0 0L0 81.5h1440.5z"/></svg>
</section>