jQuery通過(guò)ajax快速批量提交表單數(shù)據(jù)
當(dāng)表單數(shù)據(jù)項(xiàng)很多時(shí),手動(dòng)獲取表單項(xiàng)的值將變得效率低下,結(jié)合jQuery提供的函數(shù)serialize(),我們可以實(shí)現(xiàn)快速獲取數(shù)據(jù)并提交表單數(shù)據(jù)。
請(qǐng)看下面的表單:
<form id="fm"> <table> <tr> <td>姓名</td> <td> <input type="text" name="name" /> </td> </tr> <tr> <td>年齡</td> <td> <input type="text" name="age" /> </td> </tr> <tr> <td>密碼</td> <td> <input type="password" name="password" /> </td> </tr> <tr> <td>性別</td> <td> <input type="radio" name="sex" value="male" />男 <input type="radio" name="sex" value="female" />女 </td> </tr> <tr> <td>地區(qū)</td> <td> <select name="area"> <option value="heping">和平區(qū)</option> <option value="nankai">南開(kāi)區(qū)</option> <option value="xiqing">西青區(qū)</option> <option value="hexi">河西區(qū)</option> </select> </td> </tr> <tr> <td>愛(ài)好</td> <td> <input type="checkbox" name="hobby[]" value="movie" />電影 <input type="checkbox" name="hobby[]" value="music" />音樂(lè) <input type="checkbox" name="hobby[]" value="basketball" />籃球 </td> </tr> <tr> <td>個(gè)人介紹</td> <td> <textarea name="intro" ></textarea> </td> </tr> <tr> <td></td> <td> <input type="button" value="提交" id="submit" /> </td> </tr> </table> </form>
我們可以通過(guò)自定義函數(shù)getFormData()來(lái)獲取表單的數(shù)據(jù),請(qǐng)看下面的例子:
$(function(){
$('#submit').click(function(){
//選取表單
var form = $('#fm');
//獲取表單數(shù)據(jù)
var data = getFormData(form);
//發(fā)送AJAX請(qǐng)求
$.post('test.php',data,function(data){
console.log('ok');
});
});
});
getFormData()的實(shí)現(xiàn)很簡(jiǎn)單:
function getFormData(form){
var data = form.serialize();
data = decodeURI(data);
var arr = data.split('&');
var item,key,value,newData={};
for(var i=0;i<arr.length;i++){
item = arr[i].split('=');
key = item[0];
value = item[1];
if(key.indexOf('[]')!=-1){
key = key.replace('[]','');
if(!newData[key]){
newData[key] = [];
}
newData[key].push(value);
}else{
newData[key] = value;
}
}
return newData;
}
test.php接收到的數(shù)據(jù)將會(huì)是:
Array ( [name] => 3241324 [age] => m_admin [password] => 123 [sex] => male [area] => heping [hobby] => Array ( [0] => movie [1] => music ) [intro] => 321432423 )
和普通的表單提交的數(shù)據(jù)格式是一樣的,我們可以很方便的進(jìn)行處理!
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- jquery ajax實(shí)現(xiàn)批量刪除具體思路及代碼
- PHP jQuery+Ajax結(jié)合寫(xiě)批量刪除功能
- PHP ajax+jQuery 實(shí)現(xiàn)批量刪除功能實(shí)例代碼小結(jié)
- JQuery+ajax實(shí)現(xiàn)批量上傳圖片(自寫(xiě))
- JQuery DataTable刪除行后的頁(yè)面更新利用Ajax解決
- jQuery之a(chǎn)jax刪除詳解
- jQuery ajax中使用confirm,確認(rèn)是否刪除的簡(jiǎn)單實(shí)例
- 如何從jQuery的ajax請(qǐng)求中刪除X-Requested-With
- jQuery+css3實(shí)現(xiàn)Ajax點(diǎn)擊后動(dòng)態(tài)刪除功能的方法
- 基于php(Thinkphp)+jquery 實(shí)現(xiàn)ajax多選反選不選刪除數(shù)據(jù)功能
- jQuery+ajax實(shí)現(xiàn)批量刪除功能完整示例
相關(guān)文章
autoPlay 基于jquery的圖片自動(dòng)播放效果
效果類(lèi)似這種,自動(dòng)播放,實(shí)質(zhì)控制層的顯示隱藏。需要的朋友可以參考下。2011-12-12
easyUI 實(shí)現(xiàn)的后臺(tái)分頁(yè)與前臺(tái)顯示功能示例
這篇文章主要介紹了easyUI 實(shí)現(xiàn)的后臺(tái)分頁(yè)與前臺(tái)顯示功能,結(jié)合實(shí)例形式分析了easyUI 后臺(tái)數(shù)據(jù)交互、分頁(yè)與前臺(tái)顯示相關(guān)操作技巧及注意事項(xiàng),需要的朋友可以參考下2020-06-06
jQuery插件實(shí)現(xiàn)無(wú)縫滾動(dòng)特效
今天給大家分享一款頁(yè)面無(wú)縫滾動(dòng)的jquery插件,支持上下左右,淡入淡出,滾動(dòng)時(shí)間設(shè)置,動(dòng)畫(huà)時(shí)間設(shè)置,感興趣的小伙伴們可以參考一下2015-11-11
jQuery實(shí)現(xiàn)的表格前端排序功能示例
這篇文章主要介紹了jQuery實(shí)現(xiàn)的表格前端排序功能,涉及jQuery針對(duì)表格元素的獲取、遍歷及事件響應(yīng)相關(guān)操作技巧,需要的朋友可以參考下2017-09-09
jQuery插件jPaginate實(shí)現(xiàn)無(wú)刷新分頁(yè)
我改了下源碼基本可以在ie7,ie8,ie9正常顯示。以下是部分源碼。發(fā)現(xiàn)用別人的東西出了問(wèn)題很難搞啊。關(guān)鍵是那個(gè)ie啊。2015-05-05
JQuery入門(mén)——事件切換之hover()方法應(yīng)用介紹
謂切換事件,即有兩個(gè)以上的事件綁定于一個(gè)元素,在元素的行為動(dòng)作間進(jìn)行切換,有兩個(gè)方法用于事件的切換,一個(gè)方法是hover(),另一個(gè)是toggle(),感興趣的朋友不妨了解下,或許對(duì)你有所幫助2013-02-02

