我想使用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

其他回答

你可以这样做:

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

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

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

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

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

});

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

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

例如:

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

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

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

在jQuery我更喜欢以下:

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

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

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