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


当前回答

这取决于您是正常提交表单还是通过AJAX调用提交表单。你可以在jquery.com上找到大量的信息,包括带有示例的文档。要正常提交表单,请检出该站点的submit()方法。对于AJAX,有许多不同的可能性,尽管您可能希望使用AJAX()或post()方法。请注意,post()实际上只是一种调用ajax()方法的方便方法,该方法具有简化且有限的接口。

一个我每天都在使用的重要资源,你应该收藏它——How jQuery Works。它有使用jQuery的教程,左侧导航可以访问所有文档。

例子:

正常的

$('form#myForm').submit();

AJAX

$('input#submitButton').click( function() {
    $.post( 'some-url', $('form#myForm').serialize(), function(data) {
         // ... do something with response from server
       },
       'json' // I expect a JSON response
    );
});

$('input#submitButton').click( function() {
    $.ajax({
        url: 'some-url',
        type: 'post',
        dataType: 'json',
        data: $('form#myForm').serialize(),
        success: function(data) {
                   // ... do something with the data...
                 }
    });
});

注意上面的ajax()和post()方法是等价的。还可以向ajax()请求添加其他参数来处理错误等等。

其他回答

你必须使用$("#formId").submit()。

您通常会在函数中调用它。

例如:

<input type='button' value='Submit form' onClick='submitDetailsForm()' />

<script language="javascript" type="text/javascript">
    function submitDetailsForm() {
       $("#formId").submit();
    }
</script>

你可以在Jquery网站上获得更多信息。

注意,在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

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

$("#submit").click(function (event) {
  $(this).attr("type", "submit");
  $(this).click();
});
jQuery("a[id=atag]").click( function(){

    jQuery('#form-id').submit();      

            **OR**

    jQuery(this).parents("#form-id").submit();
});

你可以这样做:

$('#myform').bind('submit', function(){ ... });