The goal is to access and edit a SVG document rendered via an iFrame with a Base64 data URI.
Accessing the SVG document yields a cross-origin error, even though the iFrame is rendered locally via a data URI.
What's the right way to access a SVG document rendered via an iFrame with a data URI?
jquery.min.js:2 Uncaught DOMException: Blocked a frame with origin "http://localhost:3000" from accessing a cross-origin frame. at new w.fn.init (https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js:2:25204) at w (https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js:2:896) at getSVGElemTest (http://localhost:3000/javascripts/editorView.js?1552693529:231:18) at :1:1
Code
function getSVGElemTest() {
var svgElem = $("#svgTest iframe")[0].contentWindow).find("svg").first();
return svgElem;
}
HTML
<div id="svgTest">
<iframe src=""></iframe>
</div>
Update for @Kaiido's answer:
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);