我想使用jQuery提交一个表单。有人能提供代码,演示或示例链接吗?
当前回答
$("form:first").submit();
看到事件/提交。
其他回答
注意,在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
这取决于您是正常提交表单还是通过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 - ajax/post现在你可以:
hang onto the submit - event of your form prevent default functionality of submit do your own stuff $(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... } }); }); });
请注意,为了使serialize()函数在上面的示例中工作,所有表单元素都需要定义它们的name属性。
表单示例:
<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我更喜欢以下:
$("#form-id").submit()
但话又说回来,你真的不需要jQuery来执行这个任务-只需使用常规的JavaScript:
document.getElementById("form-id").submit()
你也可以使用jquery表单插件使用ajax提交:
http://malsup.com/jquery/form/
推荐文章
- 可以在setInterval()内部调用clearInterval()吗?
- 无法读取未定义的属性“msie”- jQuery工具
- jQuery:执行同步AJAX请求
- jQuery表格排序
- 如何禁用文本选择使用jQuery?
- 如何停止事件冒泡复选框点击
- Bootstrap抛出Uncaught错误:Bootstrap的JavaScript需要jQuery
- 如何删除和清除所有的本地存储数据
- 如何修改标签文本?
- 如何获得十六进制颜色值而不是RGB值?
- 如何将一个标题转换为jQuery的URL段塞?
- $(window).width()与媒体查询不一样
- AJAX请求中的内容类型和数据类型是什么?
- 如何打破_。在underscore.js中的每个函数
- 如何在jQuery中获得当前日期?