阻止访问使用数据URI呈现的SVG文档:访问跨域框架错误

时间:2019-03-15 23:53:14

标签: javascript jquery html svg cross-domain

目标是访问和编辑通过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);

1 个答案:

答案 0 :(得分:1)

是的,数据URL文档为considered different origin。 您可以使用Blob URL来实现相同目的,而不受此限制。

const blob = new Blob([markup], { type: "image/svg+xml" });
const url = URL.createObjectURL(blob);