vue 组件el-tree添加结构指示线条

效果展示:

注意:组件中需要添加:indent="0" 进行子级缩进处理,否则会出现子级缩进逐级递增

 :expand-on-click-node="false" 设置点击箭头图标才会展开或者收起

代码:

<el-tree class="tree filter-tree" 
    :data="treeList" 
    :props="defaultProps" 
    default-expand-all 
    :indent="0"
    :expand-on-click-node="false" 
    @node-click="handleNodeClick" 
    :filter-node-method="filterNode" 
    highlight-current ref="tree">
</el-tree>
/* 点击树结构项的选中颜色 */
    .el-tree--highlight-current .el-tree-node.is-current>.el-tree-node__content {
        background-color: #c7d1de;
    }

    /* 树形结构节点添加连线 */
    .tree {
        .el-tree-node {
            position: relative;
            padding-left: 20px;
            /* 缩进量 */
        }

        .el-tree-node__children {
            padding-left: 20px;
            /* 缩进量 */
        }

        /* 竖线 */
        .el-tree-node::before {
            content: "";
            height: 100%;
            width: 1px;
            position: absolute;
            left: -3px;
            top: -26px;
            border-width: 1px;
            border-left: 1px dashed #52627C;
        }

        /* 当前层最后一个节点的竖线高度固定 */
        .el-tree-node:last-child::before {
            height: 38px;
            /* 可以自己调节到合适数值 */
        }

        /* 横线 */
        .el-tree-node::after {
            content: "";
            width: 24px;
            height: 20px;
            position: absolute;
            left: -3px;
            top: 16px;
            border-width: 1px;
            border-top: 1px dashed #52627C;
        }

        /* 去掉最顶层的虚线,放最下面样式才不会被上面的覆盖了 */
        &>.el-tree-node::after {
            border-top: none;
        }

        &>.el-tree-node::before {
            border-left: none;
        }

        /* 展开关闭的icon */
        .el-tree-node__expand-icon {
            font-size: 16px;

            /* 叶子节点(无子节点) */
            &.is-leaf {
                color: transparent;
                /* 也可以去掉 */
                display: none;
            }
        }

    }

### el-tree 组件拖拽时标线扩大的解决方案 当处理 `el-tree` 组件的拖拽功能时,可能会遇到拖拽过程中标线显示不正常或扩大等问题。为了有效解决这一问题,可以从以下几个方面入手: #### 1. CSS样式调整 通过自定义CSS来控制拖拽过程中的标线样式是一个常见方法。可以通过覆盖Element UI默认样式的方式实现更精确的控制。 ```css /* 自定义拖拽线条样式 */ .el-tree-node__expand-icon.is-leaf { display: none; } .custom-drag-line { border-left: 2px dashed #ccc !important; /* 调整边框宽度和颜色 */ } ``` 对于特定场景下的样式微调,可以在JavaScript逻辑中动态添加或移除类名以适应不同状态的需求[^1]。 #### 2. JavaScript事件监听与DOM操作 利用原生JavaScript或者Vue框架提供的生命周期钩子,在节点被拖动前、拖动期间以及放置后的各个阶段执行相应的DOM操作,从而达到优化用户体验的目的。 ```javascript // Vue实例内methods部分 handleDragStart(event, node) { event.dataTransfer.effectAllowed = 'move'; this.draggingNode = node; // 动态设置拖拽指示器样式 document.querySelector('.custom-drag-indicator').classList.add('active'); }, handleDrop(event, targetNode) { const dragKey = this.draggingNode.key; const dropKey = targetNode.key; // 更新数据源并重置样式 updateTreeNodePosition(dragKey, dropKey); document.querySelector('.custom-drag-indicator').classList.remove('active'); this.draggingNode = null; } ``` 上述代码片段展示了如何在拖拽开始(`dragstart`) 和结束 (`drop`) 的时候分别做准备动作和清理工作,并且适时地改变页面上某些元素的状态以提供更好的视觉反馈给用户[^2]。 #### 3. 使用第三方库辅助开发 考虑到复杂度较高的需求,还可以考虑引入一些成熟的开源项目作为补充工具,比如DnD List (https://github.com/SortableJS/Vue.Draggable),它能够很好地支持树形结构的数据交换行为,同时也提供了丰富的配置选项用于定制化交互体验。 综上所述,针对`el-tree`组件中存在的拖拽标线异常情况,建议先尝试从简单的CSS层面解决问题;如果效果不佳再深入到脚本逻辑甚至借助外部资源完成最终目标。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值