【发布时间】:2011-08-28 03:24:14
【问题描述】:
我在一个 CMS 网站上工作,其域是:
http://www.acmssite.com
他们有一个存储表单系统的子域:
http://www.forms.acmssite.com
我在第一个有一个 iframe,它在后者中查看一个表单。
我需要运行脚本来从前者操作后者,我想知道这可能吗?
【问题讨论】:
标签: javascript iframe cross-domain subdomain
我在一个 CMS 网站上工作,其域是:
http://www.acmssite.com
他们有一个存储表单系统的子域:
http://www.forms.acmssite.com
我在第一个有一个 iframe,它在后者中查看一个表单。
我需要运行脚本来从前者操作后者,我想知道这可能吗?
【问题讨论】:
标签: javascript iframe cross-domain subdomain
为了不受同源策略的限制,您可能需要在两个页面中都这样做:
document.domain = "acmssite.com";
【讨论】:
document.domain = "example.com"; 似乎是 IE11 中的一个大回归,请让我知道任何解决方法谢谢!
<meta http-equiv="x-ua-compatible" content="IE=10">。您必须使用有效的文档类型。
是的。
var iframe = document.getElementById("your-iframes-id").contentWindow.document;
【讨论】:
即使您无权访问接收窗口的标题部分,您仍然可以在 YQL 的帮助下绕过此问题。使用 Postmessage 方法,您还需要编辑收件人窗口脚本。但是使用这种方法,您可以加载任何 iframe,而无需触及它们的脚本。看一下这个! jsfiddle-link
<html>
<iframe src="https://google.com/" width="500" height="300"></iframe>
<script>
var iframe = document.getElementsByTagName('iframe')[0];
var url = iframe.src;
var getData = function (data) {
if (data && data.query && data.query.results && data.query.results.resources && data.query.results.resources.content && data.query.results.resources.status == 200) loadHTML(data.query.results.resources.content);
else if (data && data.error && data.error.description) loadHTML(data.error.description);
else loadHTML('Error: Cannot load ' + url);
};
var loadURL = function (src) {
url = src;
var script = document.createElement('script');
script.src = 'https://query.yahooapis.com/v1/public/yql?q=select%20*%20from%20data.headers%20where%20url%3D%22' + encodeURIComponent(url) + '%22&format=json&diagnostics=true&env=store%3A%2F%2Fdatatables.org%2Falltableswithkeys&callback=getData';
document.body.appendChild(script);
};
var loadHTML = function (html) {
iframe.src = 'about:blank';
iframe.contentWindow.document.open();
iframe.contentWindow.document.write(html.replace(/<head>/i, '<head><base href="' + url + '"><scr' + 'ipt>document.addEventListener("click", function(e) { if(e.target && e.target.nodeName == "A") { e.preventDefault(); parent.loadURL(e.target.href); } });</scr' + 'ipt>'));
iframe.contentWindow.document.close();
}
loadURL(iframe.src);
</script>
</html>
【讨论】: