当前位置:首页 > VUE

vue实现树穿梭

2026-03-26 21:01:12VUE

Vue 实现树形穿梭框

在 Vue 中实现树形穿梭框(Tree Transfer)可以通过结合树形控件和穿梭框组件完成。以下是实现方法:

使用 Element UI 的 Tree 和 Transfer 组件

Element UI 提供了 Tree 和 Transfer 组件,可以组合实现树形穿梭框功能。

安装 Element UI:

npm install element-ui

在 Vue 文件中引入 Tree 和 Transfer 组件:

import { Tree, Transfer } from 'element-ui'

定义数据和方法:

vue实现树穿梭

export default {
  data() {
    return {
      treeData: [
        {
          id: 1,
          label: '一级 1',
          children: [
            { id: 4, label: '二级 1-1' }
          ]
        },
        {
          id: 2,
          label: '一级 2',
          children: [
            { id: 5, label: '二级 2-1' },
            { id: 6, label: '二级 2-2' }
          ]
        }
      ],
      transferData: [],
      targetKeys: []
    }
  },
  methods: {
    filterMethod(query, item) {
      return item.label.indexOf(query) > -1
    }
  }
}

模板部分:

<el-transfer
  v-model="targetKeys"
  :data="transferData"
  :titles="['源列表', '目标列表']"
  :filter-method="filterMethod"
  filterable>
</el-transfer>

<el-tree
  :data="treeData"
  show-checkbox
  node-key="id"
  @check-change="handleCheckChange">
</el-tree>

自定义树形穿梭框实现

如果需要更自定义的功能,可以完全自己实现树形穿梭框。

定义组件结构:

vue实现树穿梭

<div class="tree-transfer">
  <div class="source-tree">
    <tree :data="sourceData" @node-click="handleNodeClick"></tree>
  </div>
  <div class="transfer-buttons">
    <button @click="moveToTarget">></button>
    <button @click="moveToSource"><</button>
  </div>
  <div class="target-tree">
    <tree :data="targetData"></tree>
  </div>
</div>

处理数据移动逻辑:

methods: {
  handleNodeClick(node) {
    this.selectedNode = node
  },
  moveToTarget() {
    if (this.selectedNode) {
      this.targetData.push(this.selectedNode)
      this.sourceData = this.sourceData.filter(item => item.id !== this.selectedNode.id)
    }
  },
  moveToSource() {
    if (this.selectedNode) {
      this.sourceData.push(this.selectedNode)
      this.targetData = this.targetData.filter(item => item.id !== this.selectedNode.id)
    }
  }
}

使用第三方组件

也可以考虑使用专门为 Vue 开发的树形穿梭框组件,如 vue-tree-transfer

安装:

npm install vue-tree-transfer

使用:

import TreeTransfer from 'vue-tree-transfer'

export default {
  components: { TreeTransfer },
  data() {
    return {
      data: [
        { id: 1, label: 'Node 1', children: [...] }
      ],
      value: []
    }
  }
}
<tree-transfer
  :data="data"
  v-model="value"
  :props="{ label: 'label', children: 'children', key: 'id' }">
</tree-transfer>

以上方法提供了不同复杂度的实现方案,可以根据项目需求选择合适的实现方式。

标签: vue
分享给朋友:

相关文章

vue实现单点

vue实现单点

Vue 实现单点登录(SSO)方案 单点登录(SSO)允许用户在多个相关但独立的系统中使用同一组凭证登录。以下是基于 Vue 的实现方案: 基于 OAuth2/OpenID Connect 的实现…

vue功能实现

vue功能实现

Vue 功能实现指南 Vue.js 是一个渐进式 JavaScript 框架,广泛用于构建用户界面。以下是 Vue 功能的常见实现方法。 数据绑定 Vue 的核心功能之一是数据绑定,通过 v-mod…

vue实现素材

vue实现素材

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

vue 全景实现

vue 全景实现

Vue 全景实现方案 在Vue中实现全景效果,通常需要结合WebGL或第三方库来处理3D场景渲染。以下是几种常见方法: 使用Three.js库 Three.js是一个强大的WebGL库,适合创建3D…

vue代理实现

vue代理实现

Vue 代理实现方法 在 Vue 项目中,配置代理可以解决开发环境下的跨域问题,通常通过修改 vue.config.js 文件实现。以下是几种常见的代理配置方式: 基础代理配置 在 vue.conf…

vue实现dag

vue实现dag

Vue实现DAG(有向无环图) 在Vue中实现DAG(Directed Acyclic Graph,有向无环图)通常涉及数据结构的建模、可视化渲染以及交互逻辑处理。以下是关键实现步骤和示例代码: 数…