目标是访问和编辑通过iFrame使用Base64数据URI呈现的SVG文档。
即使iFrame是通过数据URI在本地呈现的,访问SVG文档也会产生跨域错误。
通过带有数据URI的iFrame访问呈现的SVG文档的正确方法是什么?
jquery.min.js:2未捕获的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);
答案 0 :(得分:1)
是的,数据URL文档为considered different origin。 您可以使用Blob URL来实现相同目的,而不受此限制。
const blob = new Blob([markup], { type: "image/svg+xml" });
const url = URL.createObjectURL(blob);