Layui 之TreeTable(树形数据表格),适用于权限、部门等

TreeTable.js下载

链接:https://pan.baidu.com/s/1lLBge_4MSSViLztwTnPfkA
提取码:whj3

一、效果图

二、前端代码

{include file='common/header'}
<div class="layui-fluid">
    <div class="layui-row layui-col-space15">
        <div class="layui-col-md12">
            <div class="layui-card layui-form">
                <div class="layui-card-header">{:__('Query conditions')}</div>
                <div class="layui-card-body layui-row layui-col-space15">
                    <div class="layui-col-md12">
                        <div class="layui-btn-group demoTable">
                            {if $check->checkPrivilege('department/add')}<button class="layui-btn " data-type="add">
                            <i class="layui-icon layui-icon-addition"></i>{:__('Add')}
                        </button>{/if}
                            {if $check->checkPrivilege('department/delete_op')} <button class="layui-btn layui-btn-danger" data-type="delAll"><i
                                class="layui-icon layui-icon-delete"></i>{:__('Delete all')}
                        </button>{/if}
                        </div>
                    </div>
                </div>
            </div>
        </div>
        <div class="layui-col-md12">
            <div class="layui-card layui-form">
                <div class="layui-card-body">
                    <table class="layui-hide" id="app" lay-filter="app"></table>
                </div>
            </div>
        </div>
    </div>
</div>
<script type="text/html" id="operate">
    {if $check->checkPrivilege('department/child')}<a class="layui-btn layui-btn-normal layui-btn-xs" lay-event="child">{:__('Add child')}</a>{/if}
    {if $check->checkPrivilege('department/edit')}<a class="layui-btn layui-btn-xs" lay-event="edit">{:__('Edit')}</a>{/if}
    {if $check->checkPrivilege('department/delete_op')}<a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="delete">{:__('Delete')}</a>{/if}
</script>
{include file='common/footer'}
<script>
    layui.config({
        base : '/static/admin/layui/lay/modules/'
    }).extend({
        treeTable : 'treeTable'
    });
    var table = null;
    layui.use(['treeTable', 'form'], function () {
        table = layui.treeTable;
        table.render({
            id: "app",
            elem: '#app',
            url: "{:url('department/lst')}",
            tree: {
                iconIndex: 1,
                isPidData: true,
                idName: 'id',//父ID
                pidName: 'parent_id',//子ID
                openName: 'open',// 是否默认展开的字段名
                //public bool open { get; set; }open字段是bool类型
            },
            cols: [[
                {field: 'id', title: 'ID', width: 100}
                , {
                    field: 'name', title: "{:__('Department name')}"
                }
                , {field: 'update_entered', title: "{:__('Update time')}"}
                , {field: 'date_entered', title: "{:__('Create time')}"}
                , {fixed: 'right', title: "{:__('Operate')}", toolbar: '#operate', width: 180}
            ]],
            page: false,
            cellMinWidth: 80,
            // toolbar: '#toolbar',
            // defaultToolbar: ['filter', 'exports', 'print']
        });
        table.on('tool(app)', function (obj) {
            let data = obj.data, id = data.id;
            switch (obj.event) {
                case 'child':
                    layer.open({
                        type: 2,
                        title: "{:__('Add %s', __('App name'))}",
                        area: ["600px", "400px"],
                        content: "{:url('department/add')}?id="+id,
                        maxmin: true,
                    });
                    break;
                case 'edit':
                    layer.open({
                        type: 2,
                        title: "{:__('Edit %s', __('App name'))}",
                        area: ["600px", "400px"],
                        content: "{:url('department/edit')}?id="+id,
                        maxmin: true,
                    });
                    break;
                case 'delete':
                    delete_op(id, "{:__('Are you sure you want to delete this item?')}");
                    break;
            }
        });

        var active = {
            add: function () {
                layer.open({
                    type: 2,
                    title: "{:__('Add %s', __('App name'))}",
                    area: ["600px", "550px"],
                    content: "{:url('department/add')}",
                    maxmin: true,
                });
            },
            delAll: function () {
                var checkStatus = table.checkStatus('app'),
                    data = checkStatus.data, ids="";

                if (data.length == 0) {
                    layer.msg("{:__('Please select the item to delete')}", {
                        icon: 5,
                        shift: 6
                    });
                    return false;
                }
                for (let i = 0; i < data.length; i++) {
                    if (i == data.length - 1) {
                        ids += data[i].id;
                    }else {
                        ids += data[i].id + ",";
                    }
                }
                delete_op(ids, "{:__('Are you sure you want to delete this item?')}");
            }
        };

        $('.layui-btn').on('click', function() {
            var type = $(this).data('type');
            active[type] && active[type].call(this);
        });

        function delete_op(id, msg) {
            layer.confirm(msg, function (index) {
                $.ajax({
                    url: "{:url('department/delete_op')}",
                    data: {id: id},
                    type: "post",
                    success: function (data) {
                        if (data.code == 1) {
                            layer.msg(data.msg, {
                                icon: 1
                            });
                            location.reload(true);
                        } else {
                            layer.msg(data.msg, {
                                icon: 5,
                                shift: 6
                            });
                        }
                        layer.close(index);
                    }
                });
                layer.close(index);
            });
        }
    });
</script>

三、后台数据

{
    "code": 0,
    "msg": "获取成功",
    "time": 1659322274,
    "data": [{
        "id": 1,
        "name": "test",
        "parent_id": 0,
        "date_entered": null,
        "update_entered": null,
        "open": true
    }, {
        "id": 2,
        "name": "h",
        "parent_id": 1,
        "date_entered": null,
        "update_entered": null,
        "open": true
    }, {
        "id": 3,
        "name": "222",
        "parent_id": 1,
        "date_entered": null,
        "update_entered": null,
        "open": true
    }, {
        "id": 4,
        "name": "哈哈",
        "parent_id": 0,
        "date_entered": "2022-08-01 10:28:38",
        "update_entered": "2022-08-01 10:28:38",
        "open": true
    }, {
        "id": 5,
        "name": "好",
        "parent_id": 4,
        "date_entered": "2022-08-01 10:28:53",
        "update_entered": "2022-08-01 10:35:19",
        "open": true
    }],
    "count": 5
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Qt TreeTable 是一种可以展示树形数据表格控件,它以树的形式展示数据,并且支持自定义。 首先,我们需要创建一个 QTreeWidget 控件作为 TreeTable 的容器,然后使用 setColumnCount() 方法设置表格的列数,使用 setHeaderLabels() 方法设置表头的标签。接下来,我们可以使用 QTreeWidgetItem 类来创建树节点,使用 addTopLevelItem() 方法将节点添加到 TreeTable 中。使用 addChild() 方法可以创建子节点,使用 setText() 方法设置节点的文本内容。 为了实现自定义功能,可以使用 QTreeWidgetItem 的 setFlags() 方法设置节点的标志。例如,使用 Qt.ItemIsEditable 标志可以让节点可编辑,使用 Qt.ItemIsSelectable 标志可以让节点可选中。 此外,Qt 的信号与槽机制可以用来处理 TreeTable 中的事件。我们可以使用 itemClicked() 信号来处理节点点击事件,使用 itemChanged() 信号来处理节点内容改变事件。 为了更好地显示树形结构,可以使用 setIndentation() 方法设置节点之间的缩进宽度。还可以使用 setFirstItemColumnSpanned() 方法设置是否将第一列的单元格合并成一个单元格。 总之,Qt TreeTable 提供了丰富的功能和自定义选项,可以让我们灵活地展示和操作树形数据。 ### 回答2: Qt的TreeTable是一种在QTreeView和QAbstractTableModel的基础上自定义的树形表格控件。它允许我们以树的形式显示数据,同时保留表格的布局。 首先,我们可以继承QAbstractTableModel来自定义我们的模型。在模型中,我们需要实现一些关键的函数,比如rowCount()、columnCount()、data()和headerData()等。这些函数负责提供模型所需的数据。 然后,我们可以使用QTreeView来显示树形结构。通过设置树形表格的模型为我们自定义的模型,即可将数据以树的形式显示出来。 除了基本的显示外,我们还可以对树形表格进行一些自定义的操作。例如,通过重写QAbstractItemModel的flags()函数来设置每个项的标志。我们可以根据实际需求设置是否允许编辑、是否可选中等。 另外,我们可以为树形表格添加一些自定义的功能,比如展开和折叠节点、添加和删除节点等。通过响应合适的信号和槽函数,我们可以实现这些功能。 总之,Qt的TreeTable是一种强大的树形表格控件,可以满足我们开发中对树形结构展示和编辑的需求。通过继承QAbstractTableModel和QTreeView,结合自定义的功能和操作,我们可以灵活地定制出符合自己需求的树形表格控件。 ### 回答3: Qt的TreeTable是一种用于展示树型结构数据表格控件,并且它支持自定义功能。在使用Qt的TreeTable控件时,我们可以通过自定义来实现一些特殊的功能。 首先,通过继承QAbstractItemModel类,我们可以实现自定义的树形结构数据模型。通过重写QAbstractItemModel类的一些方法,我们可以自定义节点的层次关系、节点数据的获取与更新,并且支持自定义节点样式。 其次,可以自定义树形表格的视图类,继承自QTableView类。通过重写视图类的一些方法,我们可以实现自定义的表格样式和展示效果。例如,可以设置不同的节点展开或折叠图标,并对表格的列进行自定义排序。 另外,Qt还提供了QStyledItemDelegate类,可以通过继承该类,自定义每个单元格的显示样式。通过重写QStyledItemDelegate类的paint()方法,我们可以自定义单元格的绘制方式,包括背景色、字体、图标等。 最后,Qt还提供了信号与槽机制,可以通过自定义的槽函数来实现一些特殊的功能需求。例如,可以通过监测节点的展开与折叠信号,来动态加载子节点数据,实现懒加载的效果。 总之,Qt的TreeTable控件支持自定义的功能非常丰富,通过自定义数据模型、视图以及节点样式,以及利用信号与槽机制,我们可以实现各种各样的树形表格需求,并提供更好的用户体验。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

样子2018

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值