java jquery提交表单_使用jQuery提交表单

回答(22)

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

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

$('.my-button').click(function (event) {

var $target = $( event.target );

$target.closest("form").submit();

});

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

你可以这样做:

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

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

你可以像这样使用它:

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

要么

document.formName.submit();

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

function form_submit(form_id,filename){

$.post(filename,$("#"+form_id).serialize(), function(data){

alert(data);

});

}

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

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

请注意,在Internet Explorer中,动态创建的表单存在问题 . 像这样创建的表单不会在IE(9)中提交:

var form = $('

' +

'

');

$(form).submit();

要使它在IE中工作,请创建表单元素并在提交之前附加它,如下所示:

var form = document.createElement("form");

$(form).attr("action", "/test/Delete")

.attr("method", "post");

$(form).html('');

document.body.appendChild(form);

$(form).submit();

document.body.removeChild(form);

像示例1中那样创建表单然后附加它将不起作用 - 在IE9中它会抛出JScript错误 DOM Exception: HIERARCHY_REQUEST_ERR (3)

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

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

$("#submit").click(function(event) {

$(this).attr('type','submit');

$(this).click();

});

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

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

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

动态表单的IE技巧:

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

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

在jQuery中我更喜欢以下内容:

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

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

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

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

当你有一个现有的表单,现在应该使用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 属性 .

表格示例:

..

.

@PtF - 在此示例中使用POST提交数据,这意味着您可以通过POST访问数据

$_POST['dataproperty1']

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

这里是使用CodeIgniter的示例语法:

$pdata = $this->input->post();

$prop1 = $pdata['prop1'];

$prop1 = $pdata['prop2'];

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

供参考

如果有人使用

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

do not use any

花了很多时间才发现我,submit()不会像这样工作 .

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

你将不得不使用 $("#formId").submit() .

您通常会在函数内调用它 .

例如:

function submitDetailsForm() {

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

}

您可以在Jquery website上获得有关此内容的更多信息 .

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

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

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

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

var a=$('#yourform').serialize();

$.ajax({

type:'post',

url:'receiver url',

data:a,

beforeSend:function(){

launchpreloader();

},

complete:function(){

stopPreloader();

},

success:function(result){

alert(result);

}

});

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

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

使用此代码提交表单而无需知道ID:

function handleForm(field) {

$(field).closest("form").submit();

}

例如,如果您想要处理按钮的click事件,则可以使用

$("#buttonID").click(function() {

handleForm(this);

});

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

这取决于您是正常提交表单还是通过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() 请求以处理错误等 .

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

请注意,如果您已经为表单安装了一个提交事件监听器,则提前调用submit()

jQuery('#').submit( function(e){

e.preventDefault();

// maybe some validation in here

if ( ) jQuery('#').submit();

});

won't 正在尝试为此表单的提交事件(失败)安装新的事件侦听器 . 所以你必须访问HTML元素本身(从jQquery解包)并直接调用此元素的submit():

jQuery('#').submit( function(e){

e.preventDefault();

// note the [0] array access:

if ( ) jQuery('#')[0].submit();

});

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

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

$(function(){

$('form.ajax_submit').submit(function() {

$(this).ajaxSubmit();

//validation and other stuff

return false;

});

});

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

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

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

**OR**

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

});

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

$(document).ready(function () {

$( "#button" ).click(function() {

$( "#form" ).submit();

});

});

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

e15298c6a3b4591803e154ab0c3b3e2e.png

2 years ago

我还使用以下内容通过Ajax提交表单(实际上没有提交):

jQuery.get("process_form.php"+$("#form_id").serialize(), {},

function() {

alert("Okay!");

});

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值