jQuery 實(shí)現(xiàn)批量提交表格多行數(shù)據(jù)的方法
批量提交用jquery操作起來(lái)還是很方便的,主要的思路就是 在動(dòng)態(tài)生成表格時(shí)每一行都存下這條數(shù)據(jù)的唯一id,然后監(jiān)聽(tīng)選擇,把選中的數(shù)據(jù)放入數(shù)組,最后提交到后臺(tái)就OK了。
先上一部分代碼(這是表頭以及一個(gè)全選按鈕)
<table class="ui_table ui_table_hover ui_table_striped ui_table_style02 table_fixed">
<tr>
<th width="3%" class="align_c">
<input type="checkbox" onclick="chooseAll()" id="chooseAll" name="chooseAll"/>
</th>
<th width="5%">平臺(tái)日期</th>
<th width="5%">交易日期</th>
</tr>
<tbody id="querydata">
</tbody>
</table>
chooseAll函數(shù),判斷全選按鈕是否選中,然后遍歷復(fù)選框做相應(yīng)的選擇。知識(shí)點(diǎn):
jQuery 選擇器
| 選擇器 | 實(shí)例 | 選取 |
|---|---|---|
| * | $("*") | 所有元素 |
| #id | $("#lastname") | id="lastname" 的元素 |
| .class | $(".intro") | 所有 class="intro" 的元素 |
我這里用到的.class
function chooseAll() {
if ($("#chooseAll").is(':checked')) {
$(".choose").attr("checked", true);
} else {
$(".choose").attr("checked", false);
}
}
如何動(dòng)態(tài)生成表格數(shù)據(jù),這里不做多說(shuō)了,下面的data是ajax返回的json數(shù)據(jù) checkbox的name全部為 ckItm,這在后面取數(shù)據(jù)的時(shí)候用到
for (var i = 0; i < data.length; i++) {
var $tr = $("<tr style='cursor:pointer;'></tr>");
var $td = $("<td class='align_c'></td>");
$tr.append($td.clone().append("<input type='checkbox' name='ckItm' value='" + data[i].platflow + "' class='choose'/>"));
$tr.append($td.clone().text(data[i].platdate ? data[i].platdate : ""));
$tr.append($td.clone().text(data[i].trandate ? data[i].trandate : ""));
$tr.appendTo($("#querydata"));
}
提交按鈕執(zhí)行的動(dòng)作就是遍歷已經(jīng)選中的checkbox,獲取值傳到后臺(tái),這里用到了數(shù)組的方式,大家也可以用分隔符。
$('input[name="ckItm"]:checked') 類型為input 且name為ckItm 并且選中的元素 .each遍歷
var list = []; list.push 向數(shù)組里面加一個(gè)元素
$('#listButton').click(function () {
var list = [];
$('input[name="ckItm"]:checked').each(function () {
list.push($(this).val());
});
if (list == "") {
$u.alert("請(qǐng)選擇需要經(jīng)辦的單據(jù)");
} else {
$u.ajax({
async: false,
url: "3002800007/batchMerSettleHandle.do",
data: {"list[]": list},
success: function (data) {
alert(data);
},
error: function (data) {
}
});
}
});
Java后臺(tái)controller @RequestParam(value = "list[]", required = false) String[] list,接受數(shù)組類型的值
@RequestMapping("/3002800007/batchMerSettleHandle")
@ResponseBody
public String batchMerSettleHandle(@RequestParam(value = "list[]", required = false) String[] list, HttpSession session) {
return JSON.toJSONString(list);
}
最后效果:

最后祝大家大吉大利!
以上這篇jQuery 實(shí)現(xiàn)批量提交表格多行數(shù)據(jù)的方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
JQuery 獲取和設(shè)置Select選項(xiàng)的代碼
JQuery獲取和設(shè)置Select選項(xiàng)2010-02-02
Jquery全選與反選點(diǎn)擊執(zhí)行一次的解決方案
在做項(xiàng)目時(shí)遇到一個(gè)bug,checkbox全選與反選功能,只能點(diǎn)擊一次,再點(diǎn)就不起作用了,為了解決此問(wèn)題,我查找了好多資料,下面把具體解決方案整理分享給大家,需要的朋友可以參考下2015-08-08
jQuery實(shí)現(xiàn)鼠標(biāo)滑向當(dāng)前圖片高亮顯示并且其它圖片變灰的方法
這篇文章主要介紹了jQuery實(shí)現(xiàn)鼠標(biāo)滑向當(dāng)前圖片高亮顯示并且其它圖片變灰的方法,涉及jquery鏈?zhǔn)讲僮骷绊?yè)面元素樣式控制的相關(guān)技巧,需要的朋友可以參考下2015-07-07
multiSteps 基于Jquery的多步驟滑動(dòng)切換插件
這個(gè)插件支持任意步驟,具有啟動(dòng)之前函數(shù)調(diào)用功能,具有完成之后回調(diào)功能。2011-07-07
jQuery中extend()和fn.extend()方法詳解
jQuery自定義了jQuery.extend()和jQuery.fn.extend()方法.其中jQuery.extend()方法能夠創(chuàng)建全局函數(shù)或者選擇器,而jQuery.fn.extend()方法能夠創(chuàng)建jQuery對(duì)象方法.2015-06-06
jquery和javascript中如何將一元素的內(nèi)容賦給另一元素
將一元素的內(nèi)容賦給另一元素,在某些情況下還是比較實(shí)用的,下面為大家講解下jquery和javascript中是如何實(shí)現(xiàn)的2014-01-01
基于jQuery的可以控制左右滾動(dòng)及自動(dòng)滾動(dòng)效果的代碼
迷上jQuery,相對(duì)于原生JavaScript,它是如此的美妙.也因此,促使我更加的努力的研習(xí)原生JavaScript.2010-07-07
JQuery的read函數(shù)與js的onload不同方式實(shí)現(xiàn)
JQuery的read函數(shù)與js的onload,想必大家對(duì)這兩個(gè)方法都有所熟悉吧,接下來(lái)介紹一個(gè)實(shí)例用以上兩種方法各自實(shí)現(xiàn),感興趣的你可不要錯(cuò)過(guò)了哈,希望可以幫助到你2013-03-03

