当前位置:首页 > VUE

vue实现树形拖拽

2026-01-17 23:14:38VUE

Vue 实现树形拖拽的方法

使用 vue-draggable 插件

安装 vue-draggable 插件:

npm install vuedraggable --save

在组件中引入并使用:

<template>
  <draggable v-model="treeData" group="nodes" @end="onDragEnd">
    <div v-for="(item, index) in treeData" :key="item.id">
      {{ item.name }}
      <draggable v-if="item.children" v-model="item.children" group="nodes">
        <div v-for="child in item.children" :key="child.id">
          {{ child.name }}
        </div>
      </draggable>
    </div>
  </draggable>
</template>

<script>
import draggable from 'vuedraggable'

export default {
  components: { draggable },
  data() {
    return {
      treeData: [
        { id: 1, name: 'Node 1', children: [
          { id: 11, name: 'Node 1-1' }
        ]},
        { id: 2, name: 'Node 2' }
      ]
    }
  },
  methods: {
    onDragEnd() {
      console.log('Drag end', this.treeData)
    }
  }
}
</script>

使用 Element UI 的树形组件

安装 Element UI:

vue实现树形拖拽

npm install element-ui --save

实现拖拽功能:

<template>
  <el-tree
    :data="treeData"
    draggable
    @node-drop="handleDrop"
  />
</template>

<script>
export default {
  data() {
    return {
      treeData: [
        { label: 'Node 1', children: [
          { label: 'Node 1-1' }
        ]},
        { label: 'Node 2' }
      ]
    }
  },
  methods: {
    handleDrop(draggingNode, dropNode, dropType) {
      console.log('Drop event', draggingNode, dropNode, dropType)
    }
  }
}
</script>

自定义实现拖拽功能

通过 HTML5 的拖拽 API 实现:

vue实现树形拖拽

<template>
  <div class="tree">
    <div
      v-for="item in treeData"
      :key="item.id"
      draggable="true"
      @dragstart="handleDragStart($event, item)"
      @dragover.prevent
      @drop="handleDrop($event, item)"
    >
      {{ item.name }}
      <div v-if="item.children" class="children">
        <div
          v-for="child in item.children"
          :key="child.id"
          draggable="true"
          @dragstart="handleDragStart($event, child)"
          @dragover.prevent
          @drop="handleDrop($event, child)"
        >
          {{ child.name }}
        </div>
      </div>
    </div>
  </div>
</template>

<script>
export default {
  data() {
    return {
      treeData: [
        { id: 1, name: 'Node 1', children: [
          { id: 11, name: 'Node 1-1' }
        ]},
        { id: 2, name: 'Node 2' }
      ],
      draggingNode: null
    }
  },
  methods: {
    handleDragStart(event, node) {
      this.draggingNode = node
      event.dataTransfer.setData('text/plain', node.id)
    },
    handleDrop(event, targetNode) {
      if (this.draggingNode === targetNode) return
      // 实现节点移动逻辑
      console.log('Move', this.draggingNode, 'to', targetNode)
    }
  }
}
</script>

<style>
.tree {
  user-select: none;
}
.children {
  margin-left: 20px;
}
</style>

使用 vue-tree-dnd 插件

专门用于树形拖拽的插件:

npm install vue-tree-dnd --save

基本用法:

<template>
  <tree :data="treeData" :options="options" @change="onTreeChange"/>
</template>

<script>
import { Tree } from 'vue-tree-dnd'

export default {
  components: { Tree },
  data() {
    return {
      treeData: [
        { id: 1, name: 'Node 1', children: [
          { id: 11, name: 'Node 1-1' }
        ]},
        { id: 2, name: 'Node 2' }
      ],
      options: {
        drag: true,
        drop: true
      }
    }
  },
  methods: {
    onTreeChange(newTree) {
      this.treeData = newTree
    }
  }
}
</script>

注意事项

  • 树形数据结构需要包含唯一标识符(如 id)
  • 拖拽时需要处理父子节点关系
  • 移动节点后需要更新整个树结构
  • 复杂操作可能需要递归处理数据

以上方法可以根据项目需求选择合适的方式实现树形拖拽功能。

标签: 拖拽vue
分享给朋友:

相关文章

vue实现素材

vue实现素材

Vue 实现素材的方法 使用 Vue 组件管理素材 在 Vue 项目中,可以通过组件化的方式管理素材。创建一个专门的组件来加载和显示素材,例如图片、视频或音频文件。组件可以接收素材的路径或 URL 作…

vue课程实现

vue课程实现

Vue 课程实现方案 课程内容设计 Vue课程应从基础到高级逐步展开,涵盖Vue核心概念、组件化开发、状态管理、路由、构建工具等。基础部分包括Vue实例、模板语法、计算属性和侦听器。中级部分深入组件通…

vue实现计算

vue实现计算

Vue 实现计算的方法 在 Vue 中实现计算功能可以通过多种方式完成,主要包括计算属性(computed)、方法(methods)和侦听器(watch)。以下是具体的实现方法: 计算属性(Comp…

vue实现抽奖

vue实现抽奖

Vue 实现抽奖功能 基本抽奖逻辑 创建一个Vue组件,包含奖品列表、抽奖按钮和结果显示区域。使用随机数生成器选择奖品。 <template> <div> <…

vue实现 弹窗

vue实现 弹窗

Vue 实现弹窗的基本方法 使用 Vue 实现弹窗可以通过多种方式,包括组件化、指令、插件等。以下是几种常见的实现方法。 组件化实现弹窗 创建一个独立的弹窗组件,通过 props 控制显示与隐藏。…

vue实现hexo

vue实现hexo

Vue 集成 Hexo 的实现方法 Hexo 是一个静态博客框架,而 Vue 是一个前端框架。将 Vue 集成到 Hexo 中可以通过以下方式实现: 在 Hexo 中使用 Vue 组件 通过 Hex…