How to make a <svg> element expand or contract to its parent container?

后端 未结 5 1850
日久生厌
日久生厌 2020-11-28 02:26

The goal is to have the element expand to the size of its parent container, in this case a

, no matter how big or small that
相关标签:
5条回答
  • 2020-11-28 03:00

    @robertc has it right, but you also need to notice that svg, #container causes the svg to be scaled exponentially for anything but 100% (once for #container and once for svg).

    In other words, if I applied 50% h/w to both elements, it's actually 50% of 50%, or .5 * .5, which equals .25, or 25% scale.

    One selector works fine when used as @robertc suggests.

    svg {
      width:50%;
      height:50%;
    }
    
    0 讨论(0)
  • 2020-11-28 03:05

    The viewBox isn't the height of the container, it's the size of your drawing. Define your viewBox to be 100 units in width, then define your rect to be 10 units. After that, however large you scale the SVG, the rect will be 10% the width of the image.

    0 讨论(0)
  • 2020-11-28 03:08

    What's worked for me recently is to remove all height="" and width="" attributes from the <svg> tag and all child tags. Then you can use scaling using a percentage of the parent container's height or width.

    0 讨论(0)
  • 2020-11-28 03:10

    Suppose I have an SVG which looks like this: pic1

    And I want to put it in a div and make it fill the div responsively. My way of doing it is as follows:

    First I open the SVG file in an application like inkscape. In File->Document Properties I set the width of the document to 800px and and the height to 600px (you can choose other sizes). Then I fit the SVG into this document.

    pic2

    Then I save this file as a new SVG file and get the path data from this file. Now in HTML the code that does the magic is as follows:

    <div id="containerId">    
        <svg
        id="svgId" 
        xmlns:svg="http://www.w3.org/2000/svg"
        xmlns="http://www.w3.org/2000/svg"
        version="1.1"
        x="0"
        y="0"
        width="100%"
        height="100%"
        viewBox="0 0 800 600"
        preserveAspectRatio="none">
           <path d="m0 0v600h800v-600h-75.07031l-431 597.9707-292.445315-223.99609 269.548825-373.97461h-271.0332z" fill="#f00"/>
        </svg>
    </div>
    

    Note that width and height of SVG are both set to 100%, since we want it to fill the container vertically and horizontally ,but width and height of the viewBox are the same as the width and height of the document in inkscape which is 800px X 600px. The next thing you need to do is set the preserveAspectRatio to "none". If you need to have more information on this attribute here's a good link. And that's all there is to it.

    One more thing is that this code works on almost all the major browsers even the old ones but on some versions of android and ios you need to use some javascrip/jQuery code to keep it consistent. I use the following in document ready and resize functions:

    $('#svgId').css({
        'width': $('#containerId').width() + 'px',
        'height': $('#containerId').height() + 'px'
    });
    

    Hope it helps!

    0 讨论(0)
  • 2020-11-28 03:19

    For your iphone You could use in your head balise :

    "width=device-width"
    
    0 讨论(0)
提交回复
热议问题