我想使用jQuery提交一个表单。有人能提供代码,演示或示例链接吗?


当前回答

我的方法略有不同,将按钮更改为提交按钮,然后单击

$("#submit").click(function (event) {
  $(this).attr("type", "submit");
  $(this).click();
});

其他回答

如果按钮位于表单标签之间,我更喜欢这个版本:

$('.my-button').click(function (event) {
    var $target = $( event.target );
    $target.closest("form").submit();
});

你可以这样使用它:

  $('#formId').submit();

OR

document.formName.submit();

我的方法略有不同,将按钮更改为提交按钮,然后单击

$("#submit").click(function (event) {
  $(this).attr("type", "submit");
  $(this).click();
});

我还使用以下方法通过Ajax提交了一个表单(没有实际提交它):

  jQuery.get("process_form.php"+$("#form_id").serialize(), {}, 
    function() {
      alert("Okay!"); 
    });

注意,在Internet Explorer中,动态创建的表单存在一些问题。这样创建的表单不会在IE(9)中提交:

var form = $('<form method="post" action="/test/Delete/">' +
             '<input type="hidden" name="id" value="' + myid + '"></form>');
$(form).submit();

为了让它在IE中工作,创建表单元素并在提交之前附上它,如下所示:

var form = document.createElement("form");
$(form).attr("action", "/test/Delete")
       .attr("method", "post");
$(form).html('<input type="hidden" name="id" value="' + myid + '" />');
document.body.appendChild(form);
$(form).submit();
document.body.removeChild(form);

像例1那样创建表单,然后附加它将不起作用-在IE9中,它会抛出一个JScript错误DOM异常:

感谢Tommy W @ https://stackoverflow.com/a/6694054/694325