I need to embed an svg into html and style it in a responsive way. For regular images this worked nicely for me:
img {
max-width: 100%;
}
img[height] {
height: auto; /* if the <img> tag provides a width keep aspect ratio */
}
unfortunately this doesn't work for embedded svgs. Here is an example how it works for both an embedded svg and a svg within an img tag.
Here is an example markup:
<div>Embedded SVG:
<svg xmlns="http://www.w3.org/2000/svg" width="300px" height="300px" viewBox="0 0 100 100" preserveAspectRatio="xMidYMid meet"><circle cx="50" cy="50" r="50" /></svg>
</div>
<div>SVG as image tag:
<img src="" />
</div>
and css:
div {
resize: both;
outline: 1px solid red;
margin-bottom: 3em;
padding: 1em;
}
svg,
img {
display: block;
outline: 1px solid blue;
max-width: 100%;
height: auto;
}
scaled down both images preserve aspect their ratio but the embedded svg keeps its original height (the blue outline)
How can I avoid the embedded svg creating a white space?
You can find an example on jsfiddle.
I'd love to post screenshots but I have not enough reputation for that :/
Edit: the bug appears only in chrome. changed the title accordingly
This isn't technically a Chrome bug, but rather a gap in the SVG specifications. In particular:
That tells the browser to use the
<svg>
's height attribute as the height, unless there is conflicting CSS styles setting a different height, regardless of any consideration of the aspect ratio of the image. Now, most of us would argue that<svg>
to establish an intrinsic aspect ratio,But the specs never explicitly say that. And while Firefox interprets it that way, Chrome does not.
The non-intuitive solution is to remove the height and width attributes from the
<svg>
element, use theviewBox
attribute to establish the aspect ratio, and use CSS to specify min and max height and width.CSS:
http://jsfiddle.net/78cpD/3/
Note that the
height:auto;
style is required, because the default height style is100%
when you don't specify it as an attribute.All of which is way simpler than the method I'd been using previously, that involved wrapping the SVG in a
<div>
and defining a fixed aspect ratio using padding.Someone here came up with a jquery based workaround. that works quite well so far