Заблокирован от доступа к документу SVG, отображаемому с использованием URI данных: доступ к ошибке кадра перекрестного источника - PullRequest
0 голосов
/ 16 марта 2019

Цель состоит в том, чтобы получить доступ и отредактировать документ SVG, визуализированный через iFrame с URI данных Base64.

Доступ к документу SVG приводит к ошибке перекрестного источника, даже если iFrame визуализируется локально через данныеURI.

Как правильно обращаться к документу SVG, отображаемому через iFrame с URI данных?

jquery.min.js: 2 Uncaught DOMException: заблокирован фрейм с источником"http://localhost:3000" от доступа к фрейму перекрестного происхождения. На новом w.fn.init (https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js:2:25204) на w (https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js:2:896) на getSVGElemTest (http://localhost:3000/javascripts/editorView.js?1552693529:231:18) на: 1: 1

Код

function getSVGElemTest() {
   var svgElem = $("#svgTest iframe")[0].contentWindow).find("svg").first();

   return svgElem;
}

HTML

<div id="svgTest">
<iframe src=""></iframe>
</div>

Обновление ответа @ Kaiido:

const svgElem = DesignBox.find("svg").first();
const imageType = "image/svg+xml";
const blob = new Blob([svgElem[0]], { type: imageType });
const url = URL.createObjectURL(blob);
const svgIframe = document.createElement("iframe");
svgIframe.src = url;

ColorClassProxyBox.append(svgIframe);

1 Ответ

1 голос
/ 16 марта 2019

Да. URL-адреса данных документов считаются различными источниками . Вы можете использовать BLOB-URL для достижения того же самого, без этого ограничения.

const blob = new Blob([markup], { type: "image/svg+xml" });
const url = URL.createObjectURL(blob);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...