基于 VUE 和 element-ui 的树形穿梭框组件 el-tree-transfer

这篇博客介绍了如何在Vue项目中安装和使用el-tree-transfer组件,这是一个基于Element-UI的树形穿梭框。文章详细展示了组件的基本用法,包括如何注册组件、设置数据以及监听添加和移除事件。同时,提供了模式切换功能,支持transfer和addressList两种模式。示例代码展示了如何配置和操作树形数据。
摘要由CSDN通过智能技术生成

el-tree-fransfer 是一个基于 VUE 和 element-ui 的树形穿梭框组件,使用前请确认已经引入element-ui! 此组件功能类似于element-ui的transfer组件,但是里面的数据是树形结构! 实际上,el-tree-transfer 依赖的 element-ui 组件分别是 Checkbox 多选框,Button 按钮,和最主要的 Tree 树形控件写成。

安装依赖 el-tree-transfer

npm install el-tree-transfer --save
或
npm install el-tree-transfer -S

基本使用

<template>
    <div>
    // 你的代码
    ...
    // 使用树形穿梭框组件
    <tree-transfer :title="title" :from_data='fromData' :to_data='toData' :defaultProps="{label:'label'}" @add_btn='add' @remove_btn='remove' :mode='mode' height='540px' filter openAll>
    </tree-transfer>
    </div>
</template>

<script>
import treeTransfer from 'el-tree-transfer' // 引入

export defult {
    data(){
        return:{
        mode: "transfer", // transfer addressList
        fromData:[
            {
            id: "1",
            pid: 0,
            label: "一级 1",
            children: [
                {
                id: "1-1",
                pid: "1",
                label: "二级 1-1",
                disabled: true,
                children: []
                },
                {
                id: "1-2",
                pid: "1",
                label: "二级 1-2",
                children: [
                    {
                    id: "1-2-1",
                    pid: "1-2",
                    children: [],
                    label: "二级 1-2-1"
                    },
                    {
                    id: "1-2-2",
                    pid: "1-2",
                    children: [],
                    label: "二级 1-2-2"
                    }
                ]
                }
            ]
            },
        ],
        toData:[]
        }
    },
    methods:{
        // 切换模式 现有树形穿梭框模式transfer 和通讯录模式addressList
        changeMode() {
        if (this.mode == "transfer") {
            this.mode = "addressList";
        } else {
            this.mode = "transfer";
        }
        },
        // 监听穿梭框组件添加
        add(fromData,toData,obj){
            // 树形穿梭框模式transfer时,返回参数为左侧树移动后数据、右侧树移动后数据、移动的{keys,nodes,halfKeys,halfNodes}对象
            // 通讯录模式addressList时,返回参数为右侧收件人列表、右侧抄送人列表、右侧密送人列表
            console.log("fromData:", fromData);
            console.log("toData:", toData);
            console.log("obj:", obj);
        },
        // 监听穿梭框组件移除
        remove(fromData,toData,obj){
            // 树形穿梭框模式transfer时,返回参数为左侧树移动后数据、右侧树移动后数据、移动的{keys,nodes,halfKeys,halfNodes}对象
            // 通讯录模式addressList时,返回参数为右侧收件人列表、右侧抄送人列表、右侧密送人列表
            console.log("fromData:", fromData);
            console.log("toData:", toData);
            console.log("obj:", obj);
        }
    },
    components:{ treeTransfer } // 注册
}
</script>

<style>
...
</style>

文档
el-tree-transfer文档

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值