15

iframe同一个域上,我尝试了以下代码,但没有一个起作用:

 myframe.document.getElementById("myform").submit();
 parent.top.frames[0].document.forms[0].submit(); 
 myframe.document.getElementById("myform").submit();

 MyIFrame = document.getElementById("myframe");
 myIFrame.getElementById("myform").submit();

更新:

这是 HTML:

<html>
<body>
<iframe frameborder="0" scrolling="no" width="530" height="298"
  src="/iframe.php" name="myframe" id="myframe">
  <p>iframes are not supported by your browser.</p>
</iframe><br />

<form action="/styles.css" method="post" id="form1">
<input type="text" name="input1" value=""/>
<input type="text" name="input2" value=""/>
<input type="button" value="test" onclick="submitFrame()">
<input type="submit" value="submit">
</form>

<script>

function submitFrame(){

var MyIFrame = document.getElementById("myframe");
var MyIFrameDoc = (MyIFrame.contentWindow || MyIFrame.contentDocument);
if (MyIFrameDoc.document) MyIFrameDoc = MyIFrameDoc.document;
MyIFrameDoc.getElementById("myform").submit(); // ## error 

}


</script>   
</body>
</html>

iframe.php:

<form method="post" class="af-form-wrapper" id="myform" name="myform" action="/"  >

<input type="text" name="input1" value="2073809442" />
<input type="text" name="input2" value="1" />
<input type="submit" name="submit" value="submit" />
    </form>

萤火虫 说:

 MyIFrameDoc.getElementById("myform").submit is not a function
4

3 回答 3

17

试试这个:

var MyIFrame = document.getElementById("myframe");
var MyIFrameDoc = (MyIFrame.contentWindow || MyIFrame.contentDocument);
if (MyIFrameDoc.document) MyIFrameDoc = MyIFrameDoc.document;
MyIFrameDoc.getElementById("myform").submit();

更新

我不知道为什么这不起作用,但这里有一些东西:

MyIFrameDoc.getElementById("mybutton").click();

iframe.php:

<input type="submit" name="submit" value="submit" id="mybutton" />

更新 2

您收到submit is not a function错误的原因是因为您已经命名了您的提交按钮submit,所以MyIFrameDoc.getElementById("myform").submit实际上引用了一个HTMLInputElement,而不是HTMLFormElement.submit()方法。

您需要做的就是重命名您的提交按钮,例如:

<input type="submit" name="submit2" value="submit" />
于 2012-11-06T21:45:53.823 回答
2

从 javascript 提交 iframe 的 URL

   if (window.parent.$("#IframeId").length > 0) {
        window.parent.$("#IframeId")[0].contentDocument.forms[0].submit();
    }
于 2017-06-12T08:35:39.743 回答
1

您不需要发布到 iframe。您可以使用普通的空白“可见”窗口。像这样定义您的表单:

var request = document.createElement("FORM")
request.id = "request"
request.name = "request"
request.action = "callYour.php"
request.method = "POST"
request.target = "_blank"

在您的 php 中,完成后只需通过以下方式关闭窗口:

window.close();

在 HTML 部分中,或在嵌入的脚本标签中。新窗口会暂时打开,但在完成后会自行关闭。

于 2020-02-18T05:06:26.177 回答