当前位置:首页 > 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'

定义数据和方法:

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>

自定义树形穿梭框实现

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

定义组件结构:

<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

使用:

vue实现树穿梭

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 实现评分功能 在 Vue 中实现评分功能可以通过多种方式完成,包括使用第三方组件库或自定义实现。以下是两种常见的方法: 使用第三方组件库(如 Element UI) Element UI 提…

vue实现keepalive

vue实现keepalive

Vue 中实现 keep-alive 在 Vue 中,keep-alive 是一个内置组件,用于缓存动态组件或组件的状态,避免重复渲染和销毁。以下是实现 keep-alive 的几种方法: 基本用法…

mui实现vue

mui实现vue

mui 实现 Vue 的步骤 mui 是一个轻量级的前端框架,常用于移动端开发。结合 Vue 可以实现高效的开发体验。以下是具体实现方法。 安装 mui 和 Vue 通过 npm 或 yarn 安装…

vue  实现分页

vue 实现分页

实现分页的基本思路 在Vue中实现分页通常需要结合后端API返回的数据和前端的分页组件。分页的核心逻辑包括计算总页数、处理当前页码变化以及触发数据请求。 分页组件示例 使用Element UI的分页…

vue如何实现计算

vue如何实现计算

Vue 实现计算的方法 Vue 提供了多种方式来实现计算逻辑,包括计算属性、方法、侦听器等。以下是几种常见的实现方式: 计算属性(Computed Properties) 计算属性是基于它们的响应式…

laravel vue实现登录

laravel vue实现登录

Laravel 和 Vue.js 实现登录功能 后端配置(Laravel) 安装 Laravel Sanctum 用于 API 认证 composer require laravel/sanctu…