Answers:
这取决于您是正常提交表单还是通过AJAX调用提交表单。您可以在jquery.com上找到很多信息,包括带有示例的文档。要正常提交表单,请submit()
在该站点签出方法。对于AJAX,有许多不同的可能性,尽管您可能想使用ajax()
or post()
方法。请注意,这post()
实际上是ajax()
使用简化且受限制的接口调用该方法的便捷方法。
我每天都要使用的一项重要资源,即jQuery How 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()
请求中以处理错误等。
$('form#MyForm').serialize() + '&newData=' + newData + '&moreData=' + moreData
。注意:后面两个可能需要使用进行url编码encodeURIComponent()
。或者-您可以更改为在两端使用JSON编码,但随后需要将表单数据与多余的数据放入JavaScript数据结构中并进行序列化。在这种情况下,你可能会使用serializeArray
的形式和合并的其他数据。
您将不得不使用$("#formId").submit()
。
通常,您可以从函数中调用此函数。
例如:
<input type='button' value='Submit form' onClick='submitDetailsForm()' />
<script language="javascript" type="text/javascript">
function submitDetailsForm() {
$("#formId").submit();
}
</script>
您可以在Jquery网站上获取更多信息。
当您拥有现有表单时,现在应该可以使用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...
}
});
});
});
请注意,为了使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 Doc
$("form:first").submit();
供
任何人使用的信息
$('#formId').submit();
不要这样
<button name = "submit">
花了好几个小时才发现我的commit()无法像这样工作。
"sumit"
的错字使得不清楚错字是无意回答还是与问题有关。您的意思是说一个名为"submit"
jquery 的按钮搞砸了表单Submit()吗?还是您的意思是问题在于您给按钮名称提交了而不是标准名称type="submit"
?
使用它来使用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>
button
在按钮上添加一种类型以确保表单不提交(因为并非所有浏览器都以相同的方式对待没有类型的按钮)。
这将发送带有预加载器的表格:
var a=$('#yourform').serialize();
$.ajax({
type:'post',
url:'receiver url',
data:a,
beforeSend:function(){
launchpreloader();
},
complete:function(){
stopPreloader();
},
success:function(result){
alert(result);
}
});
我有一些技巧可以使表格数据发布以随机方法重新构建http://www.jackart4.com/article.html
$("form:first").submit();
请参阅事件/提交。
请注意,如果您已经为表单安装了Submit事件侦听器,则内部调用commit()
jQuery('#<form-id>').submit( function(e){
e.preventDefault();
// maybe some validation in here
if ( <form-is-valid> ) jQuery('#<form-id>').submit();
});
在尝试为此表单的Submit事件安装新的事件侦听器(失败)时将无法工作。因此,您必须访问HTML元素本身(从jQquery中解包)并直接在此元素上调用commit():
jQuery('#<form-id>').submit( function(e){
e.preventDefault();
// note the [0] array access:
if ( <form-is-valid> ) jQuery('#<form-id>')[0].submit();
});
您还可以使用jquery表单插件使用ajax进行提交:
请注意,在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)
您可以这样使用它:
$('#formId').submit();
要么
document.formName.submit();
$.post
明确地对表单进行了解构和重构,以生成要提交的数据。谢谢!