This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
The preserveAspectRatio read-only property of the SVGViewElement interface reflects the preserveAspectRatio attribute of the given <view> element. It defines how the content within the view should be scaled to fit its viewport while preserving its aspect ratio.
An SVGAnimatedPreserveAspectRatio object.
Given the following SVG, we can use the preserveAspectRatio property to retrieve the scaling behavior for a view element:
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 200 200"> <view id="view1" preserveAspectRatio="xMidYMid meet"></view> <circle cx="100" cy="100" r="80" fill="blue" /> </svg>
We can access the preserveAspectRatio attribute:
const view = document.querySelector("view");
console.log(view.preserveAspectRatio.baseVal); // output: SVGPreserveAspectRatio {align: 1, meetOrSlice: 1}
| Desktop | Mobile | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Chrome | Edge | Firefox | Opera | Safari | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | WebView Android | WebView on iOS | |
preserveAspectRatio |
1 | 12 | 15 | ≤12.1 | 3 | 18 | 15 | ≤12.1 | 1 | 1.0 | 3 | 1 |
© 2005–2025 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/SVGViewElement/preserveAspectRatio