Jquery通过Ajax方式来提交Form表单的具体实现
Jquery通过Ajax方式来提交Form表单的具体实现
发布时间:2016-12-30 来源:查字典编辑
摘要:今天刚好看到Jquery的ajax提交数据到服务器的方法,原文是:保存数据到服务器,成功时显示信息。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数据,

复制代码 代码如下:

<form id="dlg_form" method="post">

<div>

<label> 房间:</label>

<input name="RoomName" required />

</div>

<div>

<label> 建筑:</label>

<input name="RoomName" required />

</div>

<div>

<label> 部门:</label>

<input name="RoomName" required />

</div>

<fieldset>

<legend>

<label>

<input type="checkbox" id="ktkzq" name="ktkzq" value="ktkzq"/>

空调控制器</label>

</legend>

<div>

<label> 端口:</label>

<input name="kt_dk" id="kt_dk" disabled="disabled" required />

</div>

<div>

<label> 地址:</label>

<input name="kt_dz" id="kt_dz" disabled="disabled" required />

</div>

<div>

<label> 工作方式:</label>

<input name="kt_gzfs" id="kt_gzfs" disabled="disabled" required />

</div>

<div>

<label> 是否启用:</label>

<input name="kt_sfqy" id="kt_sfqy" disabled="disabled" required />

</div>

</fieldset>

<fieldset>

<legend>

<label>

<input type="checkbox" id="dgkzq" name="dgkzq" value="dgkzq"/>

灯光控制器</label>

</legend>

<div>

<label> 端口:</label>

<input name="dg_dk" id="dg_dk" disabled="disabled" required />

</div>

<div>

<label> 地址:</label>

<input name="dg_dz" id="dg_dz" disabled="disabled" required />

</div>

<div>

<label> 工作方式:</label>

<input name="dg_gzfs" id="dg_gzfs" disabled="disabled" required />

</div>

<div>

<label> 是否启用:</label>

<input name="dg_sfqy" id="dg_sfqy" disabled="disabled" required />

</div>

</fieldset>

<div>

<label>

<input type="checkbox" id="zongbiao" name="zongbiao" value="zongbiao"/>

安装了总表:</label>

</div>

<div>

<label> 总表电能节点:</label>

<input name="zbdnjd" id="zbdnjd" disabled="disabled" required />

</div>

</form>

是不是很多,如果要你每个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,就这么简单,如果适用的话,可以拿去用哟...

呵呵.

如果有问题,也欢迎提出来.

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Javascript教程学习
热门Javascript教程学习
编程开发子分类