Vue中el-tree结合vuedraggable实现跨组件元素拖拽

实现效果:

左侧el-tree:

复制代码
<template>
    <el-tree
      class="filter-tree"
      :data="treeData"
      :props="defaultProps"
      :filter-node-method="filterNode"
      node-key="id"
      draggable
      :allow-drop="allowDrop"
      @node-drag-start="handleDragStart"
      @node-drag-end="handleDragEndz"
      ref="tree">
    </el-tree>
</template>
<script>
    data() {
        return {
            treeData:[],
            defaultProps: {
                children: 'children',
                label: 'datasetColumnName'
            },
        }
    },
    methods: {
        filterNode(value, data) {
            if (!value) return true;
            return data.datasetColumnName.indexOf(value) !== -1;
        },
        // 阻止el-tree默认拖拽
        allowDrop() {
            return false;
        },
        handleDragStart() {
            console.log(node.data)
            if(!node.data.aqlStr) return
            this.draggingItem = node.data
            this.isShowDragging = true
        },
        handleDragEndz() {
            this.isShowDragging = false
        },
    }
</script>

右侧vuedraggable接收,先npm install vuedraggable,main.js中引入:

import draggable from 'vuedraggable';

Vue.use(draggable)

使用如下:

复制代码
<draggable v-model="dragList" class="drag_list" :class="{ 'hint': isShowDragging?true:false }" animation="1000"  group="items" @dragover="handleDragOver" @drop="handleTargetDrop($event)">
    <div class="add_tip" v-if="dragList.length <= 0">
        <i class="el-icon-plus"></i>
    </div>
    <template v-else v-for="(item, index) in dragList" :key="index">
        其他代码
    </template>
</draggable>
<script>
    export default {
        data() {
            return {}
        },
        methods: {
            handleDragOver(e) {
                e.preventDefault();
            },
            handleTargetDrop(e, index) {
                e.preventDefault();
                // 阻止冒泡
                e.stopPropagation();
                // 将el-tree选中的数据放入dragList中
                this.dragList.push(this.draggingItem)
                // 刷新页面
                this.$forceUpdate()
            }
        }
    
    }
</script>

文章参考:

https://blog.csdn.net/Turn_to_empty/article/details/126759544

相关推荐
hpoenixf11 分钟前
一天上线 + 零返工:我如何给复杂前端需求建立“安全感”
前端
zhangrelay1 小时前
三分钟云课实践速通--模拟电子技术-模电--SimulIDE
linux·笔记·学习·ubuntu·lubuntu
广州华水科技1 小时前
单北斗GNSS变形监测系统在水利工程安全保障中的应用与优势分析
前端
木木_王1 小时前
嵌入式Linux学习 | 数据结构 (Day05) 栈与队列详解(原理 + C 语言实现 + 实战实验 + 易错点剖析)
linux·c语言·开发语言·数据结构·笔记·学习
lkforce1 小时前
MiniMind学习笔记(三)--train_pretrain.py(预训练)
笔记·机器学习·ai·预训练·minimind·train_pretrain
yqcoder1 小时前
CSS 外边距重叠(Margin Collapsing):现象、原理与完美解决方案
前端·css
OSwich1 小时前
【 Godot 4 学习笔记】数组(Array)
笔记·学习·godot
数据皮皮侠AI1 小时前
中国城市可再生能源数据集(2005-2021)|顶刊 Sci Data 11 种能源面板
大数据·人工智能·笔记·能源·1024程序员节
其实防守也摸鱼2 小时前
面试常问问题总结--护网蓝队方向
网络·笔记·安全·面试·职场和发展·护网·初级蓝队
山楂树の2 小时前
图像标注大坑:img图片 + Canvas 叠加标注,同步放大后标注位置偏移、对不齐?详解修复方案及亚像素处理原理
前端·css·学习·canva可画