有人能告诉我这段代码出了什么问题吗?我试图用JavaScript提交一个表单,但是一个错误”。提交不是一个函数”。查看下面的代码的更多细节:

<form action="product.php" method="get" name="frmProduct" id="frmProduct" enctype="multipart/form-data">

<input onclick="submitAction()" id="submit_value" type="button" name="submit_value" value="">

</form>

<script type="text/javascript">
    function submitAction()
    {
        document.frmProduct.submit();
    }
</script>

我还试过这个:

<script type="text/javascript">
    function submitAction()
    {
        document.forms["frmProduct"].submit();
    }
</script>

两者都显示了相同的错误:(


当前回答

你可以试试

<form action="product.php" method="get" name="frmProduct" id="frmProduct" enctype="multipart/form-data">

<input onclick="submitAction(this)" id="submit_value" type="button" name="submit_value" value="">

</form>

<script type="text/javascript">
function submitAction(element)
{
    element.form.submit();
}
</script>

你不是有不止一份同名的表格吗?

其他回答

你应该使用下面的代码: 美元(文档)。On ("ready", function () { document.frmProduct.submit (); });

如果表单没有<button type="submit">submit</button>. submit()将不起作用。表单元素属于HTMLFormElement接口,因此,我们可以直接从prototype调用,这个方法对任何表单元素都有效。

HTMLFormElement.prototype.submit.call(form)

我的解决方案是设置按钮的“form”属性

<form id="form_id_name"><button name="btnSubmit" form="form_id_name" /></form>

或者是js:

YOURFORMOBJ.getElementsByTagName("button")[0].setAttribute("form", "form_id_name");
YOURFORMOBJ.submit();

使用getElementById:

document.getElementById ('frmProduct').submit ()

抱歉回答晚了,但对于那些仍然面临同样错误的人。消除此错误:

<form method="POST">
  <input type="text"/>
  <input type="submit" id="submit-form" value="Submit Form" style="display: none;"/>
</form>

<!-- Other element that will submit the form -->
<button onclick="submitTheForm()">Submit the form</button>

<script>
function submitTheForm(){
  document.getElementById("submit-form").click();
}
</script>

解释:

javascript函数submitTheForm()正在访问提交输入元素并调用其上的click事件,从而导致表单提交。

这个解决方案是终身的,几乎100%兼容所有浏览器。