Vue 使用樹形穿梭框
Vue 項目里面需要一個樹形的穿梭框,但是 elementUI 和 ant-d 組件庫的穿梭框組件效果都不是很好,因為源列表和目標列表都是需要樹形結構的,所以說這個就很難搞,但是也不怕,因為大佬太多了,有插件可以提供給我們使用,接下來介紹一下這個插件。
樹形穿梭框插件
el-tree-transfer
這個插件很好的實現了vue項目樹形穿梭框的功能。
安裝
https://www.npmjs.com/package/el-tree-transfer
上面的連接是npm插件地址,安裝步驟也很簡單。
npm install el-tree-transfer --save
或
npm i 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>
沒有什么難的,所以說就直接粘貼代碼了,樣式可以根據自己的需要稍微調整一下就可以了。完成!
補充一下,就是回顯的時候,會顯得時候我們把選中的值直接付給 toData 之后,發現 fromData 還是有的,所以說我們需要在給 toData 賦值之后,對 fromData 過濾一下,把 toData 有的給刪掉。