使用jQuery提交表单

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

1400915 次浏览

从手册:jQuery文档

$("form:first").submit();

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

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

例如:

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


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

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

$("form:first").submit();

看到# EYZ0。

你也可以使用jquery表单插件使用ajax提交:

http://malsup.com/jquery/form/

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

我每天使用的一个重要资源是jQuery的工作原理,你应该收藏它。它有使用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我更喜欢以下:

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

但话又说回来,你真的不需要jQuery来执行这个任务-只需使用常规的JavaScript:

document.getElementById("form-id").submit()

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

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

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

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


});
function  form_submit(form_id,filename){
$.post(filename,$("#"+form_id).serialize(), function(data){
alert(data);
});
}

它将通过AJAX在给定的文件名上发布表单数据。

jQuery("a[id=atag]").click( function(){


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


**OR**


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

你可以这样做:

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

注意,在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 Exception: HIERARCHY_REQUEST_ERR (3)

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

这将发送一个带有预加载器的表单:

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

我有一些技巧,使一个表单数据post随机方法http://www.jackart4.com/article.html改革

动态表单的IE技巧:

$('#someform').find('input,select,textarea').serialize();

到目前为止,解决方案都要求您知道表单的ID。

使用以下代码在不需要知道ID的情况下提交表单:

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

例如,如果您想处理按钮的单击事件,您可以使用

$("#buttonID").click(function() {
handleForm(this);
});

你可以这样使用它:

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

document.formName.submit();

当你有一个现有的表单,现在应该使用jquery - ajax/post现在你可以:

  • 保留表单的提交事件
  • 防止默认功能提交
  • 做你自己的事

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

Please note that, in order for the serialize() function to work in the example above, all form elements need to have their name attribute defined.

Example of the form:

<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 -在这个例子中,数据是使用POST提交的,所以这意味着你可以通过

 $_POST['dataproperty1']

,其中dataproperty1是json中的“变量名”。

如果你使用CodeIgniter,这里是示例语法:

 $pdata = $this->input->post();
$prop1 = $pdata['prop1'];
$prop1 = $pdata['prop2'];

使用jquery提交表单。 下面是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>

注意,如果您已经为表单安装了提交事件侦听器,则内部调用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();
});

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

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

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

$("#submit").click(function (event) {
$(this).attr("type", "submit");
$(this).click();
});
< p > < br >的信息 如果有人使用

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

# EYZ0

<button name = "submit">

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