layui可折叠展开数据表格中嵌套表格功能实现

  

可折叠展开layui数据表格中嵌套表格功能实现思路:

1、最外层的表格先渲染,在done回调中向每个tr后面插入一个用来嵌套子级表格的tr。

tr的class和table的id需要用索引 i 关联

 //向每一行tr后面追加显示子table的tr
                        let trEles = $(".layui-table-view[lay-id=list] tbody tr");
                        for (let i = 0; i < trEles.length; i++) {
                            let childTr = `<tr class="childTR${i+1}">
                        <td></td>
                        <td colspan="16" >
                         <div class="child-table-item">
                            <table id="childTable${i + 1}"></table>
                         </div>
                        </td>
                        </tr>`;
                            $(trEles[i]).after(childTr);
                        }
2、插入完成后再渲染所有的子级表格
//渲染表格
                        for (let i = 0; i < trEles.length; i++) {
                            table.render({
                                elem: `#childTable${i + 1}`
                                , height: "300"
                                , url: "/hkj/Acount/GetSalaryList" //数据接口
                                , method: "POST"
                                , where: {
                                    lsh: tabData[i].lsh,
                                    ListMark: 'jqgrid'
                                }
                                , even: true
                                , page: true //开启分页
                                , cols: [[ //表头
                                    { field: 'NAME', title: '姓名'}
                                    , { field: 'DeptName', title: '部门' }
                                    , { field: 'BS', title: '基本工资' }
                                    , { field: 'PS', title: '岗位工资' }
                                    , { field: 'PB', title: '绩效工资' }
                                    , { field: 'SS', title: '工龄工资' }
                                    , { field: 'PA', title: '通讯补贴' }
                                    , { field: 'TA', title: '交通补贴' }
                                    , { field: 'MA', title: '餐费补贴' }
                                    , { field: 'OA', title: '其他补贴' }
                                    , { field: 'THP', title: '实发工资' }
                                ]]
                                , request: {
                                    pageName: 'pageIndex' //页码的参数名称,默认:page
                                    , limitName: 'pageSize' //每页数据量的参数名,默认:limit
                                }
                                , parseData: function (res) { //res 即为原始返回的数据
                                    return {
                                        "code": 0, //解析接口状态
                                        "msg": "加载成功", //解析提示文本
                                        "count": res.records || 0, //解析数据长度
                                        "data": res.rows //解析数据列表
                                    };
                                }
                            })
                        }
 3、最后监听箭头显示和隐藏对应的表格
 //点击箭头隐藏或显示
                        $(".showOrHide").click(function () {
                            let classStr = $(this).attr("class");
                            let index = $(this).data("index");
                            if (classStr.indexOf("layui-icon-triangle-r") > -1) {
                                //显示
                                $(this).removeClass("layui-icon-triangle-r");
                                $(this).addClass("layui-icon-triangle-d");
                                $(`.childTR${index}`).show();
                            } else {
                                //隐藏
                                $(this).removeClass("layui-icon-triangle-d");
                                $(this).addClass("layui-icon-triangle-r");
                                $(`.childTR${index}`).hide();
                            }
                            
                        })
完整代码:
layui.use('table', function () {
                let table = layui.table;
 
                //第一个实例
                mainTable = table.render({
                    elem: '#list'
                    , height: "full-100"
                    , url: '/hkj/Acount/GetData' //数据接口
                    , method: "POST"
                    , where: {
                        month: searchMonth,
                        jybz: jybz,
                        dataName: "gz",
                        ListMark: 'jqgrid'
                    }
                    ,even:true
                    , page: true //开启分页
                    , cols: [[ //表头
                        {
                            field: 'id', title: '', width: 30, templet: function (d) {
                                return `<i class="layui-icon layui-icon-triangle-d main-color main-cursor showOrHide" data-index=${d.LAY_INDEX}></i>`;
                            }
                        }
                        , { field: 'yfs1', title: '管理费用',minWidth:70 }
                        , { field: 'yfs2', title: '销售费用', minWidth: 70 }
                        , { field: 'yfs3', title: '研发费用', minWidth: 70 }
                        , { field: 'yfs4', title: '生产车间费', minWidth:90 }
                        , { field: 'yfs6', title: '生产管理费', minWidth: 90 }
                        , { field: 'sb', title: '代扣社保', minWidth: 70 }
                        , { field: 'gjj', title: '代扣公积金', minWidth: 90 }
                        , { field: 'gs', title: '代扣个税', minWidth: 70 }
                        , { field: 'qt', title: '其他代扣', minWidth: 70 }
                        , { field: 'sfgz', title: '实发银行', minWidth: 70 }
                        , { field: 'sfgz_xj', title: '实发现金', minWidth: 70 }
                        , { field: 'yfs5', title: '办公室', minWidth: 70 }
                        , { field: 'credenceNum', title: '凭证号', minWidth: 60 }
                        , {
                            field: 'bzxx', title: '备注', minWidth: 50, templet: function (d) {
                                return `<span style="color:red;">${d.bzxx}</span>`;
                            }
                        }
                        , {
                            field: 'url', title: 'excel', minWidth: 50, templet: function (d) {
                                return `<a target="_blank" href="${d.url}" class="main-color main-hover">查看</a>`;
                            }
                        }
                        , {
                            field: 'lsh', title: '操作', minWidth: 210, templet: function (rowObiect) {
                                let str = '';
                                let b = '';
                                if (!rowObiect.credenceNum) {
                                    if (rowObiect.bzxx.indexOf('[') != -1) {
                                        let a = rowObiect.bzxx.split('[')[1];
                                        b = a.split(']')[0];
                                    }
                                    str += '<a class="layui-btn layui-btn-xs del_public addKM" data-subjkey="' + b + '" data-name="" data-id="' + rowObiect.ID + '"> 添加为科目</a>';
                                    str += '<a class="layui-btn layui-btn-xs del_public pzPreview" data-id="' + rowObiect.ID + '"> 生成凭证</a>';
                                } else {
                                    str += '<a class="layui-btn layui-btn-xs del_public lookPZ" data-id="' + rowObiect.credenceNum + '"> 查看凭证</a>';
                                }
 
                                str += '<a style="color:#fff" class="layui-btn layui-btn-danger layui-btn-xs del_public delete-btn"  data-id="' + rowObiect.lsh + '"> 删除</a>'
 
                                return str
                            }
                        }
                    ]]
                    , request: {
                        pageName: 'pageIndex' //页码的参数名称,默认:page
                        , limitName: 'pageSize' //每页数据量的参数名,默认:limit
                    }
                    , parseData: function (res) { //res 即为原始返回的数据
                        return {
                            "code": res.Status ? 0 : -1, //解析接口状态
                            "msg": res.Message, //解析提示文本
                            "count": res.Data.records || 0, //解析数据长度
                            "data": res.Data.rows //解析数据列表
                        };
                    }
                    , done: function (res, curr, count) {
                        let tabData = res.data || [];
                        //向每一行tr后面追加显示子table的tr
                        let trEles = $(".layui-table-view[lay-id=list] tbody tr");
                        for (let i = 0; i < trEles.length; i++) {
                            let childTr = `<tr class="childTR${i+1}">
                        <td></td>
                        <td colspan="16" >
                         <div class="child-table-item">
                            <table id="childTable${i + 1}"></table>
                         </div>
                        </td>
                        </tr>`;
                            $(trEles[i]).after(childTr);
                        }
 
                        //渲染表格
                        for (let i = 0; i < trEles.length; i++) {
                            table.render({
                                elem: `#childTable${i + 1}`
                                , height: "300"
                                , url: "/hkj/Acount/GetSalaryList" //数据接口
                                , method: "POST"
                                , where: {
                                    lsh: tabData[i].lsh,
                                    ListMark: 'jqgrid'
                                }
                                , even: true
                                , page: true //开启分页
                                , cols: [[ //表头
                                    { field: 'NAME', title: '姓名'}
                                    , { field: 'DeptName', title: '部门' }
                                    , { field: 'BS', title: '基本工资' }
                                    , { field: 'PS', title: '岗位工资' }
                                    , { field: 'PB', title: '绩效工资' }
                                    , { field: 'SS', title: '工龄工资' }
                                    , { field: 'PA', title: '通讯补贴' }
                                    , { field: 'TA', title: '交通补贴' }
                                    , { field: 'MA', title: '餐费补贴' }
                                    , { field: 'OA', title: '其他补贴' }
                                    , { field: 'THP', title: '实发工资' }
                                ]]
                                , request: {
                                    pageName: 'pageIndex' //页码的参数名称,默认:page
                                    , limitName: 'pageSize' //每页数据量的参数名,默认:limit
                                }
                                , parseData: function (res) { //res 即为原始返回的数据
                                    return {
                                        "code": 0, //解析接口状态
                                        "msg": "加载成功", //解析提示文本
                                        "count": res.records || 0, //解析数据长度
                                        "data": res.rows //解析数据列表
                                    };
                                }
                            })
                        }
                        
                        //点击箭头隐藏或显示
                        $(".showOrHide").click(function () {
                            let classStr = $(this).attr("class");
                            let index = $(this).data("index");
                            if (classStr.indexOf("layui-icon-triangle-r") > -1) {
                                //显示
                                $(this).removeClass("layui-icon-triangle-r");
                                $(this).addClass("layui-icon-triangle-d");
                                $(`.childTR${index}`).show();
                            } else {
                                //隐藏
                                $(this).removeClass("layui-icon-triangle-d");
                                $(this).addClass("layui-icon-triangle-r");
                                $(`.childTR${index}`).hide();
                            }
                            
                        })
                    }
                });
 
            });
相关文章