效果:
使用方法:
mergeCellsByField(“Table_ShouKuan”,”FContractNO,FBizDate,FTotalAmountNoTax,FTotalAmount,FPersonName,FGroupName”, “0,1,2,3,4,5”);
/**
* EasyUI DataGrid根据字段动态合并单元格
* param tableID 要合并table的id
* param colList 要合并的列,用逗号分隔(例如:"name,department,office");
* param mainColIndex 要合并的列索引集(针对要合并的列)
例如:"0,1,2" 当然也可以是"0"也可以是"0,1"或者"1,2"这样
*/
//datagrid 合并行 2017年8月29日10:33:21 Denny
function mergeCellsByField(tableID, colList, ColIndexArr) {
var ColArray = colList.split(",");
var indexArr = ColIndexArr.split(",");
var tTable = $('#' + tableID);
var TableRowCnts = tTable.datagrid("getRows").length;
var tmpA;
var tmpB;
var PerTxt = "";
var CurTxt = "";
var alertStr = "";
for (var i = 0; i <= TableRowCnts ; i++) {
//整理逻辑如果 几个关键列数据相等
debugger
var tmp = ""
if (i == TableRowCnts) {
CurTxt = "";
}
else {
for (var kk = 0; kk < indexArr.length; kk++) {
tmp += tTable.datagrid("getRows")[i][ColArray[indexArr[kk]]];
}
CurTxt = tmp
}
if (PerTxt == CurTxt) {
tmpA += 1;
}
else {
tmpB += tmpA;
for (var j = 0; j < ColArray.length; j++) {
tTable.datagrid('mergeCells', {
index: i - tmpA,
field: ColArray[j],
rowspan: tmpA,
colspan: null
});
}
tmpA = 1;
}
PerTxt = CurTxt;
}
}