SVG height incorrectly calculated in Webkit browsers

后端 未结 9 462
轻奢々
轻奢々 2020-12-24 12:26

I have a issue specific to Webkit browsers (Safari & Chrome, on Mac & PC).

I\'m using Raphael JS to render SVG data and using a responsive layout to scale th

相关标签:
9条回答
  • 2020-12-24 12:40

    I found that adding "position: absolute;" to the image element (if it's within a parent that's also absolutely positioned), which had my .svg being called, made the "height: 100%;" declaration become relative to its container instead of the page/browser/device.

    Tested this on both Chrome and Safari (mobile webkit) for iOS 7.1, and it fixed my problem (the .svg file was going way outside of its container).

    Hopefully this a somewhat reliable fix for others here who were having trouble. Worth a shot?

    0 讨论(0)
  • 2020-12-24 12:42

    I just set the height to a very large size in the svg to maintain the aspect ratio. Using 100% comes with too many problems. This works better for me because I did not want to use js.

    Full props to: http://www.seowarp.com/blog/2011/06/svg-scaling-problems-in-ie9-and-other-browsers/

    width="1200" height="235.5"

    0 讨论(0)
  • 2020-12-24 12:46

    This is a known issue that has been fixed by the Chromium team with version 15.0.874.121. I verified this fix myself just today.

    http://code.google.com/p/chromium/issues/detail?id=98951#c27

    0 讨论(0)
  • 2020-12-24 12:46

    i know how to fix it, you have just to put this at the begining of your svg file: "preserveAspectRatio="xMinYMin none" it must be into svg tag like this:

    Problem will be fix

    0 讨论(0)
  • 2020-12-24 12:46

    I was having a problem with Javascript returning incorrect "height" values for SVGs, and I found the solution was simply to run my script (the bit that needed to access the height) on window.load rather than document.ready.

    document.ready fires when the DOM is ready, but images have not necessarily been rendered at this point. At the point where window.load fires, images will have been loaded (and thus the browser will be able to access their dimensions correctly).

    0 讨论(0)
  • 2020-12-24 12:47

    As previously pointed out WebKit's scaling of SVG improved recently. It is still quite broken in the current Safari (version 5.1, WebKit 534), in my opinion. I did a few experiments and recorded my findings on my website: http://www.vlado-do.de/svg_test/ In short: embedding svg with <object> works under most conditions in WebKit 535. For older WebKit I embed it in an <img> tag. That's fine if you don't want links inside your svg (but it does not work in older Gecko and strangely also is problematic in current Chromium).

    0 讨论(0)
提交回复
热议问题