我有一个包含iframe的应用程序。我可以修改iframe的内容,但不能修改整个页面本身,例如:
<html><head></head>
<body>
<iframe>
<!-- my code -->
</iframe>
</body></html>
我有一个要求,我需要将iframe的内容更改到不同的页面(可能在不同的域上)并返回。目前我是这样做的:第一页(它在iframe executionPanelApplications中):
<html>
<head>
<script type="text/javascript">
function replaceIFrameUrl() {
var doSubmit = "<c:out value='${param.doSubmit}'/>";
if (doSubmit == 1) {
document.forms['testForm'].submit();
}
else {
var adfUrl = "<fuego:fieldValue att='instJs.adfUrl' onlyValue='true'/>";
var bpmSrc = parent.document.getElementById('executionPanelApplications').src;
var bpmSrcParams = bpmSrc.split('&');
var activityId = (bpmSrcParams[1].split('='))[1];
var url = adfUrl +"&actionType=0&activityId="+activityId;
parent.document.getElementById('executionPanelApplications').src = url;
}
};
</script>
</head>
<body onload="replaceIFrameUrl();">
<form method="post" id="testForm" name="testForm" />
</body>
</html>
第二页(也应该在iframe executionPanelApplications中):
<script>
function leave(e) {
var iframe = parent.parent.document.getElementById("executionPanelApplications");
iframe.src = url;
};
</script>
如果两个站点都在本地主机,它就像一个魅力。不幸的是,如果它们在不同的域-第二页是在一个新的窗口打开。在ie8中测试。正如我所说的-我不能改变包含iframe的页面内容。我只能在框架内工作。我需要这个工作只在ie.
任何想法?
我不会使用iframe,因为有不同的安全限制(跨域通信)
但是我认为,这个可以帮助你:http://softwareas.com/cross-domain-communication-with-iframes