tva*_*son 456
这取决于您是正常提交表单还是通过AJAX调用.您可以在jquery.com上找到大量信息,包括带示例的文档.要正常提交表单,请查看submit()该站点的方法.对于AJAX,有许多不同的可能性,但您可能想要使用ajax()或post()方法.请注意,这post()实际上只是一种ajax()使用简化且有限的接口调用方法的便捷方式.
我每天都要使用的一个关键资源是jQuery如何工作.它有关于使用jQuery的教程,左侧导航可以访问所有文档.
例子:
正常
$('form#myForm').submit();
Run Code Online (Sandbox Code Playgroud)
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...
}
});
});
Run Code Online (Sandbox Code Playgroud)
请注意,上述ajax()和post()方法是等效的.您可以在ajax()请求中添加其他参数来处理错误等.
Dra*_*aco 120
你将不得不使用$("#formId").submit().
你通常会在一个函数中调用它.
例如:
<input type='button' value='Submit form' onClick='submitDetailsForm()' />
<script language="javascript" type="text/javascript">
function submitDetailsForm() {
$("#formId").submit();
}
</script>
Run Code Online (Sandbox Code Playgroud)
您可以在Jquery网站上获得有关此内容的更多信息.
wom*_*omd 69
当你有一个现有的表单,现在应该使用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...
}
});
});
});
Run Code Online (Sandbox Code Playgroud)请注意,为了使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>
Run Code Online (Sandbox Code Playgroud)
@PtF - 在此示例中使用POST提交数据,因此这意味着您可以通过访问您的数据
$_POST['dataproperty1']
Run Code Online (Sandbox Code Playgroud)
,其中dataproperty1是json中的"变量名".
这里是使用CodeIgniter的示例语法:
$pdata = $this->input->post();
$prop1 = $pdata['prop1'];
$prop1 = $pdata['prop2'];
Run Code Online (Sandbox Code Playgroud)
ger*_*erg 67
在jQuery中我更喜欢以下内容:
$("#form-id").submit()
Run Code Online (Sandbox Code Playgroud)
但话说回来,你真的不需要jQuery来执行该任务 - 只需使用常规JavaScript:
document.getElementById("form-id").submit()
Run Code Online (Sandbox Code Playgroud)
Ada*_*ane 40
从手册:jQuery Doc
$("form:first").submit();
Run Code Online (Sandbox Code Playgroud)
A.Z*_*oft 20
如果有人使用的信息
$('#formId').submit();
Run Code Online (Sandbox Code Playgroud)
不要使用任何
<button name = "submit">
Run Code Online (Sandbox Code Playgroud)
我花了很多时间才发现submit()不会像这样工作.
小智 14
这将发送一个带预加载器的表单:
var a=$('#yourform').serialize();
$.ajax({
type:'post',
url:'receiver url',
data:a,
beforeSend:function(){
launchpreloader();
},
complete:function(){
stopPreloader();
},
success:function(result){
alert(result);
}
});
Run Code Online (Sandbox Code Playgroud)
我有一些技巧可以使用随机方法http://www.jackart4.com/article.html重新构建表单数据
Chi*_*mar 14
使用它来使用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>
Run Code Online (Sandbox Code Playgroud)
小智 13
请注意,如果您已经为表单安装了一个提交事件监听器,那么提前调用submit()
jQuery('#<form-id>').submit( function(e){
e.preventDefault();
// maybe some validation in here
if ( <form-is-valid> ) jQuery('#<form-id>').submit();
});
Run Code Online (Sandbox Code Playgroud)
将无法正常工作,因为它尝试为此表单的提交事件(失败)安装新的事件侦听器.因此,您必须访问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();
});
Run Code Online (Sandbox Code Playgroud)
小智 7
jQuery("a[id=atag]").click( function(){
jQuery('#form-id').submit();
**OR**
jQuery(this).parents("#form-id").submit();
});
Run Code Online (Sandbox Code Playgroud)
请注意,在Internet Explorer中,动态创建的表单存在问题.像这样创建的表单不会在IE(9)中提交:
var form = $('<form method="post" action="/test/Delete/">' +
'<input type="hidden" name="id" value="' + myid + '"></form>');
$(form).submit();
Run Code Online (Sandbox Code Playgroud)
要使它在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);
Run Code Online (Sandbox Code Playgroud)
像示例1中那样创建表单然后附加它将不起作用 - 在IE9中它会抛出JScript错误 DOM Exception: HIERARCHY_REQUEST_ERR (3)
汤米W的道具@ /sf/answers/468583811/
到目前为止,解决方案要求您知道表单的ID.
使用此代码提交表单而无需知道ID:
function handleForm(field) {
$(field).closest("form").submit();
}
Run Code Online (Sandbox Code Playgroud)
例如,如果您想要处理按钮的click事件,则可以使用
$("#buttonID").click(function() {
handleForm(this);
});
Run Code Online (Sandbox Code Playgroud)
如果按钮位于表单标签之间,我更喜欢这个版本:
$('.my-button').click(function (event) {
var $target = $( event.target );
$target.closest("form").submit();
});
Run Code Online (Sandbox Code Playgroud)
小智 5
动态表单的 IE 技巧:
$('#someform').find('input,select,textarea').serialize();
Run Code Online (Sandbox Code Playgroud)
你可以这样使用它:
$('#formId').submit();
Run Code Online (Sandbox Code Playgroud)
或者
document.formName.submit();
Run Code Online (Sandbox Code Playgroud)
我的方法略有不同,将按钮更改为提交按钮,然后单击
$("#submit").click(function (event) {
$(this).attr("type", "submit");
$(this).click();
});
Run Code Online (Sandbox Code Playgroud)