Enviar um formulário com o jQuery

quero enviar um formulário usando jQuery. Alguém pode fornecer o Código, uma demo ou um link de exemplo?

 389
Author: SharpC, 2009-07-29

22 answers

Depende se está a enviar o formulário normalmente ou através de uma chamada AJAX. Você pode encontrar muita informação em jquery.com , incluindo documentação com exemplos. Para enviar um formulário normalmente, verifique submit() método para aquele local. Para AJAX, existem muitas possibilidades diferentes, que você provavelmente deseja usar o ajax() ou post() métodos. Note que post() é apenas uma maneira conveniente de chamar o ajax() Método com uma interface simplificada e limitada.

Um recurso crítico, que eu uso todos os dias, que você deve marcar é como jQuery funciona . Ele tem tutoriais sobre o uso de jQuery e a navegação à esquerda dá acesso a toda a documentação.

Exemplos:

Normal

$('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...
                 }
    });
});

Note que os métodos de ajax() e post() acima são equivalentes. Existem parâmetros adicionais que você pode adicionar ao ajax() pedido para lidar erros, etc.

 405
Author: tvanfosson, 2017-08-01 04:34:52

Terá de utilizar $("#formId").submit().

Você geralmente chamaria isso de dentro de uma função.

Por exemplo:

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

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

Você pode obter mais informações sobre isso no site Jquery.

 105
Author: Draco, 2014-01-07 10:03:46

Em jQuery eu preferiria o seguinte:

$("#form-id").submit()

Mas por outro lado, você realmente não precisa de jQuery para executar essa tarefa-basta usar o JavaScript normal:

document.getElementById("form-id").submit()
 62
Author: gernberg, 2015-07-24 11:15:32

Quando você tem uma forma existente, que agora deve trabalhar com jquery-ajax / post agora você pode:

  • segure - se no evento de submissão do seu formulário
  • impedir a funcionalidade predefinida do submit
  • Faz as tuas próprias coisas

    $(function() {
        //hang on event of form with id=myform
        $("#myform").submit(function(e) {
    
            //prevent Default functionality
            e.preventDefault();
    
            //get the action-url of the form
            var actionurl = e.currentTarget.action;
    
            //do your own request an handle the results
            $.ajax({
                    url: actionurl,
                    type: 'post',
                    dataType: 'application/json',
                    data: $("#myform").serialize(),
                    success: function(data) {
                        ... do something with the data...
                    }
            });
    
        });
    
    });
    

Por favor, note que, para que a função serialize() funcione no exemplo acima, todos os elementos da forma precisam de ter o seu atributo name definido.

Exemplo do formulário:

<form id="myform" method="post" action="http://example.com/do_recieve_request">

<input type="text" size="20" value="default value" name="my_input_field">
..
.
</form>

@PtF - os dados são enviado usando o POST nesta amostra, então isso significa que você pode acessar seus dados via

 $_POST['dataproperty1'] 

, onde dataproperty1 é um "nome-variável" no seu json.

Aqui a sintaxe da amostra se usar o código-indicador:

 $pdata = $this->input->post();
 $prop1 = $pdata['prop1'];
 $prop1 = $pdata['prop2'];
 55
Author: womd, 2017-04-27 10:16:56

Do manual: jQuery Doc

$("form:first").submit();
 34
Author: AdamSane, 2009-07-29 13:31:35

Isto enviará um formulário com o preloader:

var a=$('#yourform').serialize();
$.ajax({
    type:'post',
    url:'receiver url',
    data:a,
    beforeSend:function(){
        launchpreloader();
    },
    complete:function(){
        stopPreloader();
    },
    success:function(result){
         alert(result);
    }
});

Eu tenho algum truque para fazer um formulário de dados pós-reformada com método aleatório http://www.jackart4.com/article.html

 13
Author: jacky, 2012-11-28 04:52:13

Note que se você já instalou um ouvinte de eventos submit para o seu formulário, a chamada innner para submeter ()

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

O Won'T funciona à medida que tenta instalar um novo ouvinte de eventos para o evento de envio deste formulário (o que falha). Então você tem que acessar o elemento HTML em si (desembrulhar do jQquery) e chamar submeter() neste elemento diretamente:

    jQuery('#<form-id>').submit( function(e){ 
      e.preventDefault();
      // note the [0] array access:
      if ( <form-is-valid> ) jQuery('#<form-id>')[0].submit();
    });
 12
Author: gutschilla, 2014-04-08 23:50:41
$("form:first").submit();

Ver eventos / Submeter.

 9
Author: Ahmed, 2011-05-23 09:48:52

Use - o para enviar o seu formulário usando jquery. Aqui está o link http://api.jquery.com/submit/

<form id="form" method="post" action="#">
    <input type="text" id="input">
    <input type="button" id="button" value="Submit">
</form>

<script type="text/javascript">
$(document).ready(function () {
    $( "#button" ).click(function() {
        $( "#form" ).submit();
    });
});
</script>
 9
Author: ChintanThummar, 2018-01-23 08:57:04

Você também pode usar o 'plugin' do formulário jquery para enviar usando ajax aswell:

Http://malsup.com/jquery/form/

 8
Author: Richard, 2009-07-29 13:33:13
jQuery("a[id=atag]").click( function(){

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

            **OR**

    jQuery(this).parents("#form-id").submit();
});
 7
Author: GKumar00, 2011-09-27 06:30:21
Note que no Internet Explorer há problemas com formas criadas dinamicamente. Um formulário criado como este não será submetido em IE (9):
var form = $('<form method="post" action="/test/Delete/">' +
             '<input type="hidden" name="id" value="' + myid + '"></form>');
$(form).submit();

Para o pôr a funcionar, ou seja, criar o elemento form e anexá-lo antes de o submeter assim:

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);

Criar o formulário como no exemplo 1 e depois anexá-lo não vai funcionar-no IE9 ele lança um erro JScriptDOM Exception: HIERARCHY_REQUEST_ERR (3)

Adereços ao Tommy W @ https://stackoverflow.com/a/6694054/694325

 7
Author: Nenotlep, 2017-05-23 12:26:30

As soluções até agora requerem que você saiba o ID do formulário.

Utilize este código para enviar o formulário sem precisar de saber o ID:

function handleForm(field) {
    $(field).closest("form").submit();
}

Por exemplo, se quisesse lidar com o evento por um botão, podia usar

$("#buttonID").click(function() {
    handleForm(this);    
});
 7
Author: muzzamo, 2013-04-26 05:04:15

Para informação
se alguém utilizar

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

Não utilize qualquer

<button name = "sumit">
[[3]} demorou muitas horas para me encontrar que se submeter () não vai funcionar assim.
 7
Author: A.Z. Soft, 2018-04-12 18:08:47

Se o botão estiver localizado entre as marcas do formulário, prefiro esta versão:

$('.my-button').click(function (event) {
    var $target = $( event.target );
    $target.closest("form").submit();
});
 5
Author: Tk421, 2016-07-15 05:55:30

Podias usá - lo assim:

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

Ou

document.formName.submit();
 4
Author: Ram Ch. Bachkheti, 2013-06-21 06:22:05
Truque para formas dinâmicas:
$('#someform').find('input,select,textarea').serialize();
 4
Author: user2320873, 2013-09-12 11:45:30
function  form_submit(form_id,filename){
    $.post(filename,$("#"+form_id).serialize(), function(data){
        alert(data);
    });
}

Vai publicar os dados do formulário no seu nome de ficheiro através do AJAX.

 2
Author: kdniazi, 2011-06-22 19:55:47

A minha abordagem é ligeiramente diferente. mude o botão para o botão enviar e depois carregue em

$("#submit").click(function(event) {
$(this).attr('type','submit');
$(this).click();
});
 2
Author: NaveenDA, 2017-02-22 05:27:28

Eu recomendo uma solução genérica para que você não tenha que adicionar o código para cada formulário. Usar o 'plugin' do formulário jquery (http://jquery.malsup.com/form/) e adicionar este código.

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

});
 1
Author: danidacar, 2011-02-27 19:38:52

Podias fazer assim:

$('#myform').bind('submit', function(){ ... });
 1
Author: vdegenne, 2011-11-14 10:27:45

Também usei o seguinte para enviar um formulário (sem o Submeter de facto) através do Ajax:

  jQuery.get("process_form.php"+$("#form_id").serialize(), {}, 
    function() {
      alert("Okay!"); 
    });
 -2
Author: brian newman, 2009-07-29 13:38:27