Easyui Datagrid 根据字段动态合并行

效果:
这里写图片描述

使用方法:
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;
    }
}

猜你喜欢

转载自blog.csdn.net/qq_23502409/article/details/77675819