js竖列合并处理

参考他人的博客,稍微做了一点点改动,增加了一个传参变量,可以作为工具类使用,以下是源码。

/**
 * 列合并工具类
 * 调用eg : fnMergeRowCell($("[name=maintbody]"), [0, 1, 2], 0);
 * maintbodyObj : 需要合并列的表格对象(tbody),必填
 * limitRowOrRowIndexs : 需要合并的列,必填
 * basicIndex : 以哪一列为基准,非必填,如果没有可以选择null
 */
var fnMergeRowCell = function(maintbodyObj, limitRowOrRowIndexs, basicIndex) {
    var limitRow = null //从0~n列
    var limitRowIndex = null; //具体限制某列,如[0,4,5]

    if(limitRowOrRowIndexs == undefined || limitRowOrRowIndexs == null) {
        limitRow = null;
        limitRowIndex = null;
    } else {
        if($.isArray(limitRowOrRowIndexs)) {
            limitRowIndex = limitRowOrRowIndexs;
            limitRow = null;
        } else {
            limitRowIndex = null;
            limitRow = limitRowOrRowIndexs;
        }
    }

    if(basicIndex == null || basicIndex == undefined){
        basicIndex = null;
    }

    /**
     * 名称说明
     * 1. 主合并对象:设置rowspan的td
     * 2. 子合并对象:被隐藏的td
     * 
     * 实现原理
     * 1. 每行扫描,拿当前行和下一行做对比,如果值为一致,标记为主合并对象(在标记前要判断是否为主标记对象,如果为子标记对对象进行data-ishide 标记 ),
     * 2. 下一行自动标记上主合并对象的 data-pid
     */

    var callAttr = "data-main";
    var dataPidKey = "data-cid";
    var $tbody = $(maintbodyObj);
    var trs = $tbody.find("tr");

    for(var i = 0; i < trs.length; i++) {
        var $cr = $(trs[i]);
        var $nr = $(trs[i + 1]);

        var $crtd = $cr.find("td"); //当前行下面的td
        var $nrtd = $nr.find("td"); //下一行下面的td

        if(limitRow == null) {
            limitRow = $crtd.length;
        }

        for(var r = 0; r < limitRow; r++) {
            if(null != limitRowIndex) {
                if(limitRowIndex.indexOf(r) == -1) {
                    continue;
                }
            }

            var $crtdRow = $($crtd[r]);
            var $nrtdRow = $($nrtd[r]);

            var $crtdbRow = basicIndex == null ? "":$($crtd[basicIndex]);
            var $nrtdbRow = basicIndex == null ? "":$($nrtd[basicIndex]);

            //当前行对应的单元格的值 和 下一行对应的单元格的值相同
            if($crtdRow.html() == $nrtdRow.html() && $crtdbRow.html() == $nrtdbRow.html()) {

                var dataId = $crtdRow.attr(dataPidKey);
                //如果为隐藏,则代表着这个已经是被合并的了,需要拿到data-pid
                if($crtdRow.attr(callAttr) != "false") {
                    dataId = "coordinate_" + i + "_" + r;
                    $crtdRow.attr(callAttr, "true").attr(dataPidKey, dataId); //标记主要主合并对象
                }
                $nrtdRow.attr(callAttr, "false").attr(dataPidKey, dataId);
                $nrtdRow.hide();
            }
        }
    }

    $tbody.find("[" + callAttr + "=true]").each(function(i, _d) {
        var dataPid = $(_d).attr(dataPidKey);
        $(_d).attr("rowspan", $tbody.find("[" + dataPidKey + "=" + dataPid + "]").length).addClass("center");
    });
}

参考博客

https://blog.csdn.net/jerrydai90/article/details/56667919
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值