因此,请检查以下代码,其中包含一个带有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版本通常会小得多,例如此处。 >
答案 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。
您可以通过以下方式缓解这些问题:
background-size
。 934px 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>