如何在 jQuery 中创建具有 header 行和可折叠详细信息行的 table
How to create a table with header rows and collapsible details rows in jQuery
我在 jQuery Ajax 调用中从 Web 服务接收数据,如下所示:
[
{
"grpRecord":{
"Group1":"17658",
"Group2":"0"
},
"lstRecords":[
{
"NA":"0",
"GROUP1":"17658",
"GROUP2":"0",
"Task_Name":"01 Internal Plaster ",
"material_name":"CEMENT 43 GRADE",
"Est_Qty":"100.0000",
"Rate":"300.0000",
"EST_Mat_Amt":"30000.00000000"
},{
"NA":"0",
"GROUP1":"17658",
"GROUP2":"0",
"Task_Name":"01 Internal Plaster ",
"material_name":"CEMENT 43 GRADE ",
"Est_Qty":"220000.0000",
"Rate":"300.0000",
"EST_Mat_Amt":"66000000.00000000"
},{
"NA":"0",
"GROUP1":"17658",
"GROUP2":"0",
"Task_Name":"01 Internal Plaster ",
"material_name":"NATURAL SAND ",
"Est_Qty":"60000.0000",
"Rate":"700.0000",
"EST_Mat_Amt":"42000000.00000000"
}
]
}
]
这只是一条记录我收到了多条这样的记录。这里 'grpRecord' 应该是 table header 和 'lstRecords' 包含行详细信息。现在我的问题是,我想将 'grpRecord' 显示为 table 行,将 'lstrRecords' 作为行详细信息显示为可折叠的行详细信息。
至此我的代码是这样的:
<script type="text/javascript">
function callAjax() {
//Ajax call for drill down data START
$.ajax({
type: 'POST',
dataType: 'json',
cache: false,
url: '@Url.Action("index", "test")',
data: {},
success: function (response, textStatus, jqXHR) {
alert(response);
// document.write(JSON.stringify(response));
bindTable(response);
},
error: function (jqXHR, textStatus, errorThrown) {
alert('Error - ' + errorThrown);
}
});
//Ajax call for drill down data END
//function to bind json to table STart
function bindTable(response) {
var data = response;
alert("Response recieved");
alert(data);
for (var i = 0; i < data.length; i++) {
bindHeader(data[i]);
drawHeader(data[i], ParentID);
}
$('.DynamicTable').html('<tbody>' + createTable("0").join('') + '</tbody>');
}
//function to bind json to table End
//$("#tabHead").append('<li ><a data-toggle="tab" href="#drillData">Drill Down</a></li>'); //creating tab head
}
function bindHeader()
{
//code to bind header
}
function bindDetail()
{
//code to bind details
}
</script>
得到solution.Here是完整的ajax代码
//Ajax call for drill down data START
$.ajax({
type: 'POST',
dataType: 'json',
cache: false,
url: '@Url.Action("GetWBSReportDrillDown", "WBSBudget")',
data: { FieldId: feildId, ProjNo: ProID, TaskNo: taskNo, TreeId: treeId, FromDate: FrmDate, ToDate: TDate, UserName: "aa", CompName: "aa" },
success: function (response, textStatus, jqXHR) {
//alert(response);
// document.write(JSON.stringify(response));
bindTable(response);
},
error: function (jqXHR, textStatus, errorThrown) {
alert('Error - ' + errorThrown);
}
});
//Ajax call for drill down data END
//function to bind json to table STart
function bindTable(response) {
var data = response;
alert(data);
function createTable(parentID) {
return data.filter(function (node) { return (node.parent_id === parentID); }).sort(function (a, b) { return a.name > b.name }).map(function (node) {
return '<tr id="' + node.id + '" level="' + node.depth + '" class="' + node.depth + '"><td type="' + node.type + '" id="' + node.id + '" level="' + node.depth + '" pid="' + node.parent_id + '" level="' + node.depth + '" ><span class="level' + node.depth + ' spn" ><img src="Design/images/plus.gif" class="testnode" ></img></span><span class="nodename" id="' + node.id + '" nodetype="' + node.type + '" title="' + node.name + '">' + node.name + '</span></td><td>' + node.id + '</td><td>' + node.type + '</td></tr>';
});
}
$('.DynamicTable').html('<tbody>' + createTable("0").join('') + '</tbody>');
$(document).on("click", ".testnode", function (e) {
if (($(this).attr('src')) == 'Design/images/plus.gif') {
$(this).attr('src', 'Design/images/minus.gif');
var val = $(this).parent().parent().parent();
var parentID = $(this).parent().parent().parent().attr('id');
$(val).after(createTable(parentID).join(''));
}
else {
$(this).attr('src', 'Design/images/plus.gif');
var level = $(this).parent().parent('td').attr('level');
var tr = $(this).parent().parent().parent('tr');
while (tr.next().prop("tagName") == "TR") {
// var level = tr.next().children().attr("level");
if (tr.next().children().attr("level") != level) {
// alert(tr.next().children().attr("level") + " != " + level);
if (tr.next().children().attr("level") >= level) {
tr.next().hide();
// alert(tr.next().children().attr("level") + " > " + level);
}
}
else {
break;
}
tr = tr.next();
e.stopPropagation();
}
e.stopPropagation();
}
});
}
//function to bind json to table End
$("#tabHead").append('<li ><a data-toggle="tab" href="#drillData">Drill Down</a></li>'); //creating tab head
});
});
<div id="drillData" class="tab-pane fade">
<div class="table-responsive">
<table class="table table-hover DynamicTable" ></table>
</div>
</div>
我在 jQuery Ajax 调用中从 Web 服务接收数据,如下所示:
[
{
"grpRecord":{
"Group1":"17658",
"Group2":"0"
},
"lstRecords":[
{
"NA":"0",
"GROUP1":"17658",
"GROUP2":"0",
"Task_Name":"01 Internal Plaster ",
"material_name":"CEMENT 43 GRADE",
"Est_Qty":"100.0000",
"Rate":"300.0000",
"EST_Mat_Amt":"30000.00000000"
},{
"NA":"0",
"GROUP1":"17658",
"GROUP2":"0",
"Task_Name":"01 Internal Plaster ",
"material_name":"CEMENT 43 GRADE ",
"Est_Qty":"220000.0000",
"Rate":"300.0000",
"EST_Mat_Amt":"66000000.00000000"
},{
"NA":"0",
"GROUP1":"17658",
"GROUP2":"0",
"Task_Name":"01 Internal Plaster ",
"material_name":"NATURAL SAND ",
"Est_Qty":"60000.0000",
"Rate":"700.0000",
"EST_Mat_Amt":"42000000.00000000"
}
]
}
]
这只是一条记录我收到了多条这样的记录。这里 'grpRecord' 应该是 table header 和 'lstRecords' 包含行详细信息。现在我的问题是,我想将 'grpRecord' 显示为 table 行,将 'lstrRecords' 作为行详细信息显示为可折叠的行详细信息。
至此我的代码是这样的:
<script type="text/javascript">
function callAjax() {
//Ajax call for drill down data START
$.ajax({
type: 'POST',
dataType: 'json',
cache: false,
url: '@Url.Action("index", "test")',
data: {},
success: function (response, textStatus, jqXHR) {
alert(response);
// document.write(JSON.stringify(response));
bindTable(response);
},
error: function (jqXHR, textStatus, errorThrown) {
alert('Error - ' + errorThrown);
}
});
//Ajax call for drill down data END
//function to bind json to table STart
function bindTable(response) {
var data = response;
alert("Response recieved");
alert(data);
for (var i = 0; i < data.length; i++) {
bindHeader(data[i]);
drawHeader(data[i], ParentID);
}
$('.DynamicTable').html('<tbody>' + createTable("0").join('') + '</tbody>');
}
//function to bind json to table End
//$("#tabHead").append('<li ><a data-toggle="tab" href="#drillData">Drill Down</a></li>'); //creating tab head
}
function bindHeader()
{
//code to bind header
}
function bindDetail()
{
//code to bind details
}
</script>
得到solution.Here是完整的ajax代码
//Ajax call for drill down data START
$.ajax({
type: 'POST',
dataType: 'json',
cache: false,
url: '@Url.Action("GetWBSReportDrillDown", "WBSBudget")',
data: { FieldId: feildId, ProjNo: ProID, TaskNo: taskNo, TreeId: treeId, FromDate: FrmDate, ToDate: TDate, UserName: "aa", CompName: "aa" },
success: function (response, textStatus, jqXHR) {
//alert(response);
// document.write(JSON.stringify(response));
bindTable(response);
},
error: function (jqXHR, textStatus, errorThrown) {
alert('Error - ' + errorThrown);
}
});
//Ajax call for drill down data END
//function to bind json to table STart
function bindTable(response) {
var data = response;
alert(data);
function createTable(parentID) {
return data.filter(function (node) { return (node.parent_id === parentID); }).sort(function (a, b) { return a.name > b.name }).map(function (node) {
return '<tr id="' + node.id + '" level="' + node.depth + '" class="' + node.depth + '"><td type="' + node.type + '" id="' + node.id + '" level="' + node.depth + '" pid="' + node.parent_id + '" level="' + node.depth + '" ><span class="level' + node.depth + ' spn" ><img src="Design/images/plus.gif" class="testnode" ></img></span><span class="nodename" id="' + node.id + '" nodetype="' + node.type + '" title="' + node.name + '">' + node.name + '</span></td><td>' + node.id + '</td><td>' + node.type + '</td></tr>';
});
}
$('.DynamicTable').html('<tbody>' + createTable("0").join('') + '</tbody>');
$(document).on("click", ".testnode", function (e) {
if (($(this).attr('src')) == 'Design/images/plus.gif') {
$(this).attr('src', 'Design/images/minus.gif');
var val = $(this).parent().parent().parent();
var parentID = $(this).parent().parent().parent().attr('id');
$(val).after(createTable(parentID).join(''));
}
else {
$(this).attr('src', 'Design/images/plus.gif');
var level = $(this).parent().parent('td').attr('level');
var tr = $(this).parent().parent().parent('tr');
while (tr.next().prop("tagName") == "TR") {
// var level = tr.next().children().attr("level");
if (tr.next().children().attr("level") != level) {
// alert(tr.next().children().attr("level") + " != " + level);
if (tr.next().children().attr("level") >= level) {
tr.next().hide();
// alert(tr.next().children().attr("level") + " > " + level);
}
}
else {
break;
}
tr = tr.next();
e.stopPropagation();
}
e.stopPropagation();
}
});
}
//function to bind json to table End
$("#tabHead").append('<li ><a data-toggle="tab" href="#drillData">Drill Down</a></li>'); //creating tab head
});
});
<div id="drillData" class="tab-pane fade">
<div class="table-responsive">
<table class="table table-hover DynamicTable" ></table>
</div>
</div>