layui左树右表

html部分
<div class="layui-fluid">
    <div class="layui-row layui-col-space15">
        <!-- 左树 -->
        <div class="layui-col-sm12 layui-col-md4 layui-col-lg3">
            <div class="layui-card">
                <div class="layui-card-body mini-bar" id="ltTree">

                </div>
            </div>
        </div>
        <!-- 右表 -->
        <div class="layui-col-sm12 layui-col-md8 layui-col-lg9">
            <div class="layui-card">
                <div class="layui-card-body">

                    <div class="layui-form toolbar">
                        <div class="layui-form-item">
                            <div class="layui-inline">
                                <label class="layui-form-label w-auto">搜索:</label>
                                <div class="layui-input-inline mr0">
                                    <input id="edtSearch" class="layui-input" type="text" placeholder="输入关键字"/>
                                </div>
                            </div>
                            <div class="layui-inline" >
                                <button class="layui-btn icon-btn" id="btnSearchByCode">
                                    <i class="layui-icon">&#xe615;</i>字典编码搜索
                                </button>
                                <button class="layui-btn icon-btn" id="btnSearchByName">
                                    <i class="layui-icon">&#xe615;</i>字典值搜索
                                </button>
                            </div>
                            <div class="layui-inline">

                               <button id="btnAdd" class="layui-btn icon-btn"  >
                                    <i class="layui-icon">&#xe654;</i>新增
                                </button>
                                <button id="btnDel" class="layui-btn layui-btn-danger icon-btn"  >
                                    <i class="layui-icon">&#xe640;</i>删除
                                </button>
                            </div>
                        </div>
                    </div>

                    <table class="layui-table" id="rtTable" lay-filter="rtTable"></table>

                </div>
            </div>
        </div>

    </div>
</div>

 

js部分:(包含树加载及批量删除)

<script>

    layui.use(['layer', 'form', 'table', 'util', 'dtree','admin'], function () {
        var $ = layui.jquery;
        var layer = layui.layer;
        var form = layui.form;
        var table = layui.table;
        var util = layui.util;
        var dtree = layui.dtree;
        var admin = layui.admin;
        // 渲染表格
        var ins1 = function (pid,cloumn,Keyword){
           table.render({
               elem: '#rtTable',
               url: '/dictionary/dictionaryInfoByParentId',
               page: true,
               cellMinWidth: 100,
               cols: [[
                   {type: 'checkbox'},
                   {field: 'dictCode', align: 'center', sort: true, title: '字典编码'},
                   {field: 'dictName', align: 'center', sort: true, title: '字典值'},
                   {field: 'dictOrder', align: 'center', sort: true, title: '字典序列'},
                   {field: 'dictDescription', align: 'center', sort: true, title: '字典备注'},
                   {align: 'center', align: 'center', toolbar: '#user-table-bar', title: '操作', minWidth: 120}
               ]],
               where: {nodeId: pid,Keyword:Keyword,cloumn:cloumn}
           });
        }
        // 监听工具条
        table.on('tool(rtTable)', function (obj) {
            var data = obj.data; //获得当前行数据
            var layEvent = obj.event; //获得 lay-event 对应的值

            if (layEvent === 'edit') { // 查看
               showEditModel(data);
                //layer.msg('点击了修改');
            } else if (layEvent === 'del') { // 删除
                var deleteData = new Array();
                deleteData.push(data.dictId);
                deleteDictionary(deleteData);
            }
        });
        
        // 增加
        $('#btnAdd').click(function () {
           var param = dtree.getNowParam(dictTree);
            if (param.context) {
               admin.putTempData('selectdictionaryId', param.nodeId);
            } else {
               layer.msg('请选择一个节点', {icon: 2});
            }
            showEditModel();
        });
        // 批量删除
        $('#btnDel').click(function () {
            var checkRows = table.checkStatus('rtTable');
            if (checkRows.data.length == 0) {
                layer.msg('请选择要删除的数据', {icon: 2});
            } else {
                var deletedata = [];
                for(var i=0;i<checkRows.data.length;i++){
                   deletedata.push(checkRows.data[i].dictId);
                }
                deleteDictionary(deletedata);
            }
        });

        // 搜索按钮点击事件
        $('#btnSearchByCode').click(function () {
            var value = $('#edtSearch').val();
            ins1("","dict_code",value);
        });
     // 搜索按钮点击事件
        $('#btnSearchByName').click(function () {
            var value = $('#edtSearch').val();
            ins1("","dict_name",value);
        });
        
        
        // 树形渲染
        var dictTree = dtree.render({
            elem: '#ltTree',
            url: '/dictionary/dictionaryTreeInfo',
           // type: 'all',
            initLevel: '1',//默认展开层级,当该值大于level时,则会展开树的节点,直到不大于当前待展开节点的level
            //dot: false,
            method: 'GET',
            request:{nodeId:"0"}//自定义参数,组件进行参数拼接时,会将该属性的串拼接到url,然后传递到后台进行数据查询
        });
        // 树形点击事件
        dtree.on('node("ltTree")', function (obj) {
            var data = obj.param;
            
            //layer.msg('你选择了:' + data.nodeId + '-' + data.context);
            //table.reload('rtTable', {where: {nodeId: data.nodeId}});
            ins1(data.nodeId,"","");
        });
        
        
     // 显示表单弹窗
        function showEditModel(data) {
            admin.putTempData('dictionaryEditData', data);
            admin.putTempData('formOk', false);
            top.layui.admin.open({
                type: 2,
                title: data ? '修改字典' : '添加字典',
                area: ['480px', '492px'],
                content: '/dictionary/editForm',
                end: function () {
                    admin.getTempData('formOk') && table.reload('rtTable') // 成功刷新表格
                    if(admin.getTempData('formOk')){
                       dictTree.menubarMethod().refreshTree();
                    }
                    
                }
            });
        }
     
     
     function deleteDictionary(data){
        var postdata = {"Ids":data};
        if(data.constructor==Array||data instanceof Array){
           $.post(
                   "delete",
                   postdata,
                   function(result){
                      if (result.code == 200) {
                            top.layer.msg(result.msg, {icon: 1});
                            table.reload('rtTable')&&dictTree.menubarMethod().refreshTree();
                        } else {
                            top.layer.msg(result.msg, {icon: 2});
                        }
                   },"json"
                 );
        }
     }
     
        
    });
    
    
</script>

页面展示:

  • 2
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
Vue左树右表封装组件是一种常用的组件封装技术,用于展示有树形结构和表格结构的数据。它将左侧的树形结构和右侧的表格结构结合在一起,方便用户对数据进行查看和操作。 该组件通常包含以下两个主要部分: 1. 左侧树形结构:在左侧展示树形结构,用于展示数据的层级关系。用户可以通过点击树节点来展开或折叠子节点。树形结构的节点通常具有不同的图标或样式,以便区分不同的节点类型或状态。 2. 右侧表格结构:在右侧展示以表格形式呈现的数据。表格通常包含多列,每列对应数据的一个属性。用户可以通过排序、筛选或搜索等方式来对表格数据进行操作。 组件的封装可以提供一些可配置的参数,以便根据实际需求进行定制。例如,可以通过传递数据源、树节点的渲染函数、表格列的定义等参数来实现组件的灵活性。 使用Vue左树右表封装组件可以带来一些好处。首先,它将树形结构和表格结构有机地结合在一起,提供了直观、便捷的数据展示和操作方式。其次,组件的封装可以提高代码的重用性和可维护性,使开发过程更加高效。最后,通过合理的设计,该组件还可以实现一些高级功能,如拖拽排序、批量操作等,进一步提升用户体验。 综上所述,Vue左树右表封装组件是一种非常实用的组件封装技术,能够方便地展示和操作有树形和表格结构的数据。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值