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?
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.
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.
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()
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'];
Do manual: jQuery Doc
$("form:first").submit();
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
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();
});
$("form:first").submit();
Ver eventos / Submeter.
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>
Você também pode usar o 'plugin' do formulário jquery para enviar usando ajax aswell:
jQuery("a[id=atag]").click( function(){
jQuery('#form-id').submit();
**OR**
jQuery(this).parents("#form-id").submit();
});
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
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);
});
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.
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();
});
Podias usá - lo assim:
$('#formId').submit();
Ou
document.formName.submit();
$('#someform').find('input,select,textarea').serialize();
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.
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();
});
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;
});
});
Podias fazer assim:
$('#myform').bind('submit', function(){ ... });
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!");
});