На самом деле это не ошибка. В исходном svg атрибут preserveAspectRatio
отсутствует. Это означает, что используется значение по умолчанию, равное XMidYMid
. Это создаст проблему, если viewBox
форматное соотношение svg не соответствует форматному соотношению цели viewPort (изображение). Чтобы отключить это, вам нужно добавить preserveAspectRatio="none"
в svg. Я пошел к источнику svg, добавил атрибут preserveAspectRatio="none"
, а затем сделал это:
var x = "data:image/svg+xml;base64,"+ btoa(ser.serializeToString(document.querySelector("svg")))
ser
выше - это экземпляр XMLSerializer. Это даст мне URL-адрес данных, который я могу использовать:
""
Затем я создал скрипку и изменил это:
function createSvg() {
var img = new Image()
var prom = new Promise(function(resolve, reject) {
img.onload = function() {resolve(img)}
img.onerror = function(err) {reject(err)}
})
img.src = "";
return prom
}
Смотрите скрипку здесь:
https://fiddle.jshell.net/ibowankenobi/4ntq2qLz/1/
Похоже, это решило проблему в браузере Firefox, который я тестировал.