您好,欢迎访问一九零五行业门户网

Jquery通过Ajax方式来提交Form表单的具体实现_jquery

今天刚好看到jquery的ajax提交数据到服务器的方法,原文是:
保存数据到服务器,成功时显示信息。
jquery 代码:
复制代码 代码如下:
$.ajax({
type: post,
url: some.php,
data: name=john&location=boston,
success: function(msg){
alert( data saved: + msg );
}
});
后来我就想了一下,我要提交form表单有没有办法呢?但是我不可能每个fom的input都写一次var demo=$(#divname).val();的.
后来,今天我看到一个方法,就是.map,就做出一下想法了,可以借鉴哟;
html代码如下,下面我要提交form 的id为dlg_form的所有input数据,
复制代码 代码如下:
房间:
建筑:
部门:
空调控制器
端口:
地址:
工作方式:
是否启用:
灯光控制器
端口:
地址:
工作方式:
是否启用:
安装了总表:
总表电能节点:
是不是很多,如果要你每个input都写的话,是不是要吐血?
看看我的方法,首先我们把所有的input的name和value都取下来,
js代码如下:
复制代码 代码如下:
var str_data=$(#dlg_form input).map(function(){
return ($(this).attr(name)+'='+$(this).val());
}).get().join(&) ;
alert(data);
ps:你alert一下,你会发现,这里面的架构就是divname=xxx&divname2=xxxx等等,
然后在回头看看ajax提交的:
复制代码 代码如下:
$.ajax({
type: post,
url: some.php,
data: name=john&location=boston,
success: function(msg){
alert( data saved: + msg );
}
});
有没有发现,只要我们把我们上面获取到的,放到data里面就可以了?
完整的代码,修改后应该是
复制代码 代码如下:
$.ajax({
var str_data=$(#dlg_form input).map(function(){
return ($(this).attr(name)+'='+$(this).val());
}).get().join(&) ;
type: post,
url: some.php,
data: str_data,
success: function(msg){
alert( data saved: + msg );
}
});
ok,就这么简单,如果适用的话,可以拿去用哟...
呵呵.
如果有问题,也欢迎提出来.
其它类似信息

推荐信息