Jquery通过Ajax方式来提交Form表单的具体实现
发布时间:2020-12-14 22:44:30 所属栏目:资源 来源:网络整理
导读:今天刚好看到Jquery的ajax提交数据到服务器的方法,原文是: 保存数据到服务器,成功时显示信息。 jQuery 代码: 复制代码 代码如下: $.ajax({ type: "POST", url: "some.php", data: "name=John } }); 后来我就想了一下,我要提交form表单有没有办法呢?但是我不
今天刚好看到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 class="fitem"> <label> 房间:</label> <input name="RoomName" style="padding: 2px; width: 135px; border: 1px solid #A4BED4;" required /> </div> <div class="fitem"> <label> 建筑:</label> <input name="RoomName" class="easyui-combobox" style="padding: 2px; width: 141px; " required /> </div> <div class="fitem"> <label> 部门:</label> <input name="RoomName" class="easyui-combobox" style="padding: 2px; width: 141px; " required /> </div> <fieldset> <legend> <label> <input type="checkbox" id="ktkzq" name="ktkzq" value="ktkzq"/> 空调控制器</label> </legend> <div class="fitem"> <label> 端口:</label> <input name="kt_dk" id="kt_dk" disabled="disabled" class="easyui-combobox" style="padding: 2px; width: 141px; " required /> </div> <div class="fitem"> <label> 地址:</label> <input name="kt_dz" id="kt_dz" disabled="disabled" class="easyui-combobox" style="padding: 2px; width: 141px; " required /> </div> <div class="fitem"> <label> 工作方式:</label> <input name="kt_gzfs" id="kt_gzfs" disabled="disabled" class="easyui-combobox" style="padding: 2px; width: 141px; " required /> </div> <div class="fitem"> <label> 是否启用:</label> <input name="kt_sfqy" id="kt_sfqy" disabled="disabled" class="easyui-combobox" style="padding: 2px; width: 141px; " required /> </div> </fieldset> <fieldset> <legend> <label> <input type="checkbox" id="dgkzq" name="dgkzq" value="dgkzq"/> 灯光控制器</label> </legend> <div class="fitem"> <label> 端口:</label> <input name="dg_dk" id="dg_dk" disabled="disabled" class="easyui-combobox" style="padding: 2px; width: 141px; " required /> </div> <div class="fitem"> <label> 地址:</label> <input name="dg_dz" id="dg_dz" disabled="disabled" class="easyui-combobox" style="padding: 2px; width: 141px; " required /> </div> <div class="fitem"> <label> 工作方式:</label> <input name="dg_gzfs" id="dg_gzfs" disabled="disabled" class="easyui-combobox" style="padding: 2px; width: 141px; " required /> </div> <div class="fitem"> <label> 是否启用:</label> <input name="dg_sfqy" id="dg_sfqy" disabled="disabled" class="easyui-combobox" style="padding: 2px; width: 141px; " required /> </div> </fieldset> <div class="fitem"> <label style=" width:100px;"> <input type="checkbox" id="zongbiao" name="zongbiao" value="zongbiao"/> 安装了总表:</label> </div> <div class="fitem"> <label> 总表电能节点:</label> <input name="zbdnjd" id="zbdnjd" disabled="disabled" class="easyui-combobox" style="padding: 2px; width: 141px; " 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", 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", data: str_data, success: function(msg){ alert( "Data Saved: " + msg ); } }); ok,就这么简单,如果适用的话,可以拿去用哟... 呵呵. 如果有问题,也欢迎提出来. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |