jQuery實現(xiàn)為table表格動態(tài)添加或刪除tr功能示例
本文實例講述了jQuery實現(xiàn)為table表格動態(tài)添加或刪除tr功能。分享給大家供大家參考,具體如下:
HTML頁面元素如下:
<!-- 訂單明細(xì)dialog -->
<div id="contractDetailDiv" title="銷售訂單明細(xì)" style="display:none;">
<table class="exhibit_table" id="contractDetailTab" border="1">
<tr>
<td>訂單合同號</td>
<td colspan="4" id="orderId"></td>
</tr>
<tr>
<td>捆包號</td>
<td>品名</td>
<td>規(guī)格</td>
<td>材質(zhì)</td>
<td>重量</td>
</tr>
</table>
</div>
業(yè)務(wù)需求是,從后臺獲取到訂單合同下的明細(xì)信息,然后動態(tài)添加到上面的表格中,做法是:
1. 在jqgrid表格中為每一列添加一個“訂單明細(xì)”的圖標(biāo),如下所示:
jQuery(function($) {
var grid_selector = "#grid-table";
var pager_selector = "#grid-pager";
jQuery(grid_selector).jqGrid({
data: grid_data,
datatype: "local", //從服務(wù)器端返回的數(shù)據(jù)類型
height: 400, //表格高度,可以是數(shù)字,像素值或者百分比
/****列顯示名稱******/
colNames:['id', '訂單合同號', '收貨單位', '提貨方式', '物資來源', '物資來源廠商名稱', '訂單總重量', '綁定合同號來源', '綁定合同號', '訂單狀態(tài)', '訂單明細(xì)'],
/****常用到的屬性:name 列顯示的名稱;index 傳到服務(wù)器端用來排序用的列名稱;width 列寬度;align 對齊方式;sortable 是否可以排序******/
colModel:[
{name:'id',index:'id', width:0, sorttype:"int", editable: true, hidden:true},
{name:'goodsOrder', index:'goodsOrder', width:60, editable:true, editoptions:{size:"20",maxlength:"30"}},
{name:'goodsReceiveCompany', index:'goodsReceiveCompany', width:60, sortable:false, editable:true, editoptions:{size:"20",maxlength:"30"}},
{name:'goodsDeliveryMode', index:'goodsDeliveryMode', width:60, sortable:false, editable:true, editoptions:{size:"20",maxlength:"30"}},
{name:'goodsOrigin', index:'goodsOrigin', width:60, editable:true, editoptions:{size:"20",maxlength:"30"}},
{name:'originName', index:'originName', width:60, sortable:false, editable:true, editoptions:{size:"20",maxlength:"30"}},
{name:'contractWeight', index:'contractWeight', width:60, sortable:false, editable:true, editoptions:{size:"20",maxlength:"30"}, formatter: "number", formatoptions: {thousandsSeparator:",", defaulValue:"", decimalPlaces:3}},
{name:'purchaseContractOrigin', index:'purchaseContractOrigin', width:60, sortable:false, editable: true, editoptions:{size:"20",maxlength:"30"}},
{name:'purchaseContractOriginVal', index:'purchaseContractOriginVal', width:60, sortable:false, editable: true, editoptions:{size:"20",maxlength:"30"}},
{name:'contractStatus', index:'contractStatus', width:60, editable:true, editoptions:{size:"20",maxlength:"30"}},
{name:'myac222', index:'', width:120, fixed:true, sortable:false, resize:false, align:'center',
formatter: function (value, grid, rows, state) {
return "<a href=\"#\" title=\"訂單明細(xì)\" style=\"margin-left:10px\" onclick=\"contractDetail(" + rows.id + ")\"><i class=\"icon-bar-chart blue\" style=\"font-size:15px\"></i></a>";
}
}
],
loadonce: true, //一次加載全部數(shù)據(jù)到客戶端,由客戶端進(jìn)行排序。
sortable: true,
rownumbers: true, //添加左側(cè)行號
viewrecords: true, //定義是否要顯示總記錄數(shù)
rowNum: 10, //在grid上顯示記錄條數(shù),這個參數(shù)是要被傳遞到后臺
rowList: [10,20,30], //一個下拉選擇框,用來改變顯示記錄數(shù),當(dāng)選擇時會覆蓋rowNum參數(shù)傳遞到后臺
pager: pager_selector, //定義翻頁用的導(dǎo)航欄,必須是有效的html元素。翻頁工具欄可以放置在html頁面任意位置
altRows: true, //設(shè)置為交替行表格,默認(rèn)為false
//toppager: true,
multiselect: true, //定義是否可以多選
//multikey: "ctrlKey", //只有在multiselect設(shè)置為ture時起作用,定義使用那個key來做多選。shiftKey,altKey,ctrlKey
multiboxonly: true, //只有當(dāng)multiselect = true.起作用,當(dāng)multiboxonly 為ture時只有選擇checkbox才會起作用
gridComplete:function(){ //在此事件中循環(huán)為每一行添加修改和刪除鏈接
},
loadComplete : function() {
$(grid_selector).closest(".ui-jqgrid-bdiv").css({ 'overflow-y' : 'scroll' });
var table = this;
setTimeout(function(){
updatePagerIcons(table);
enableTooltips(table);
}, 0);
},
editurl: "???", //定義對form編輯時的url
caption: "銷售訂單列表", //表格名稱
autowidth: true //如果為ture時,則當(dāng)表格在首次被創(chuàng)建時會根據(jù)父元素比例重新調(diào)整表格寬度。如果父元素寬度改變,為了使表格寬度能夠自動調(diào)整則需要實現(xiàn)函數(shù):setGridWidth
});
上面添加“訂單明細(xì)”的圖標(biāo)時,為其綁定了onclick事件,此事件將傳遞每一行的id給綁定函數(shù)。
2. 在綁定函數(shù)中首先獲取onclick傳遞過來的行id,通過此行id可訪問該行的每個字段的數(shù)據(jù)。然后在此綁定函數(shù)中通過ajax從后臺獲取到“訂單明細(xì)”的具體數(shù)據(jù),再通過append方法將獲取到的數(shù)據(jù)動態(tài)添加到table表格中。最后,將此table表格所在的div以dialog的形式彈出來展示給用戶。如下:
/*********合同明細(xì)彈出框************/
function contractDetail(id){
$("#contractDetailTab tr:gt(0)").empty();
var rowData = $("#grid-table").jqGrid('getRowData',id);
var purchaseContractOrder = rowData.purchaseContractOriginVal;
$("#orderId").html(rowData.goodsOrder);
//請求合同明細(xì)數(shù)據(jù)
$.ajax({
async:false,
cache:true,
type: "GET",
url: "goods_findPagePurchaseOrderDetail.do?purchaseContractOrder="+purchaseContractOrder, //獲取json數(shù)據(jù)
success: function(result){
var result = eval('('+ result +')');
if(result.root != undefined && result.root.length > 0){
var resultContent = result.root;
for (var i = 0; i < resultContent.length; i++) {
$("#contractDetailTab").append("<tr><td>捆包號</td><td>品名</td><td>規(guī)格</td><td>材質(zhì)</td><td>重量</td></tr><tr><td>"+resultContent[0][0]+"</td><td>"+resultContent[0][1]+"</td><td>"+resultContent[0][2]+"</td><td>"+resultContent[0][3]+"</td><td>"+resultContent[0][5]+"</td></tr>");
}
$("#contractDetailDiv").dialog({
autoOpen:true,
height:300,
width:450,
resizable:false,
modal:true,
});
} else {
alert("該訂單合同下無明細(xì)信息!");
}
},
error: function() {
alert("獲取合同明細(xì)失敗")
}
});
}
這里需要注意的是,每次動態(tài)添加新的明細(xì)之前,需要將上一次的明細(xì)信息清空,即使用empty方法將上一次動態(tài)添加的tr先刪除掉,然后再動態(tài)添加新的明細(xì)信息。
動態(tài)刪除除第一行以外的其他tr:
$("#contractDetailTab tr:gt(0)").empty();
$("#contractDetailTab tr").not(':eq(0)').empty();
動態(tài)添加tr:
動態(tài)刪除除第一行和最后一行以外的其他tr:
$("#contractDetailTab tr:not(:first):not(:last)").remove();
更多關(guān)于jQuery相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《jQuery表格(table)操作技巧匯總》、《jQuery操作xml技巧總結(jié)》、《jQuery form操作技巧匯總》、《jQuery常用插件及用法總結(jié)》、《jQuery擴(kuò)展技巧總結(jié)》及《jquery選擇器用法總結(jié)》
希望本文所述對大家jQuery程序設(shè)計有所幫助。
- jQuery實現(xiàn)獲取table表格第一列值的方法
- JQuery Ajax動態(tài)生成Table表格
- jQuery對table表格進(jìn)行增刪改查
- 基于JQuery的動態(tài)刪除Table表格的行和列的代碼
- JQuery 動態(tài)生成Table表格實例代碼
- 使用jQuery操作HTML的table表格的實例解析
- jQuery實現(xiàn)Table表格隔行變色及高亮顯示當(dāng)前選擇行效果示例
- jQuery實現(xiàn)table表格checkbox全選的方法分析
- jQuery+CSS實現(xiàn)的table表格行列轉(zhuǎn)置功能示例
- jQuery實現(xiàn)table表格信息的展開和縮小功能示例
- jQuery動態(tài)操作表單示例【基于table表格】
相關(guān)文章
jQuery插件jRumble實現(xiàn)網(wǎng)頁元素抖動
jRumble是jquery的插件,可以讓你選擇的元素抖動。 調(diào)用時只需一句代碼即可,有些抖動效果還挺可愛,可自定義的抖動效果,十分的炫酷,有需要的小伙伴可以參考下。2015-06-06
jquery 鍵盤事件 keypress() keydown() keyup()用法總結(jié)
在本篇文章里小編給各位整理的是關(guān)于jquery 鍵盤事件 keypress() keydown() keyup()用法總結(jié)以及相關(guān)實例,需要的朋友們學(xué)習(xí)下。2019-10-10
詳談Ajax請求中的async:false/true的作用(ajax 在外部調(diào)用問題)
下面小編就為大家?guī)硪黄斦凙jax請求中的async:false/true的作用(ajax返回值在外部調(diào)用問題)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02
jquery實現(xiàn)簡單合攏與展開網(wǎng)頁面板的方法
這篇文章主要介紹了jquery實現(xiàn)簡單合攏與展開網(wǎng)頁面板的方法,通過簡單的jquery頁面元素樣式操作實現(xiàn)展開與合攏面板的功能,非常簡單實用,需要的朋友可以參考下2015-09-09

