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


当前回答

你可以这样使用它:

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

OR

document.formName.submit();

其他回答

的信息 如果有人使用

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

不是这样的吗

<button name = "submit">

我花了很长时间才发现submit()不能像这样工作。

这取决于您是正常提交表单还是通过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()请求添加其他参数来处理错误等等。

我建议使用通用的解决方案,这样就不必为每个表单添加代码。使用jquery表单插件(http://jquery.malsup.com/form/)并添加此代码。

$(function(){
$('form.ajax_submit').submit(function() {
    $(this).ajaxSubmit();
            //validation and other stuff
        return false; 
});

});

注意,如果您已经为表单安装了提交事件侦听器,则内部调用submit()

jQuery('#<form-id>').submit( function(e){ 
    e.preventDefault();
    // maybe some validation in here
    if ( <form-is-valid> ) jQuery('#<form-id>').submit();
});

不会工作,因为它试图为这个表单的提交事件安装一个新的事件侦听器(失败)。所以你必须访问HTML元素本身(从jQquery打开),并直接在这个元素上调用submit():

    jQuery('#<form-id>').submit( function(e){ 
      e.preventDefault();
      // note the [0] array access:
      if ( <form-is-valid> ) jQuery('#<form-id>')[0].submit();
    });
$("form:first").submit();

看到事件/提交。