VUE使用vue-tree-color组件实现组织架构图,并可以动态更新数据
npm
# use npm
npm install vue-tree-color
安装loader
npm install --save-dev less less-loader
导入插件
import Vue from 'vue'
import Vue2OrgTree from 'vue-tree-color'
Vue.use(Vue2OrgTree)
基本使用
开始
因为已经安装过了组件,所以可以直接使用,在vue页面中,直接使用组件标签,动态绑定data数据(data数据为递归数据即可)
<vue2-org-tree :data="data"/>
...
datas:{
id:0,
label:'一级',
children:[
{
id:11,
label:'二级1'
}
]
}
data数据放入页面中
其中,data数据中,id 每个元素不同的ID ,label为name, children为自己的子集数据
排列方式
上面图片是默认排列方式,其实还有一种水平排列方式
# 只需要加上 horizontal 即可
<vue2-org-tree :data="datas" :horizontal="true" />
效果如下
折叠展示
添加一个属性 collapsable,并添加一个组件自带方法
<vue2-org-tree :data="data" :horizontal="true" collapsable @on-expand="onExpand" />
...
methods: {
collapse(list) {
var _this = this
list.forEach(function(child) {
if (child.expand) {
child.expand = false
}
child.children && _this.collapse(child.children)
})
},
onExpand(e, data) {
if ('expand' in data) {
data.expand = !data.expand
if (!data.expand && data.children) {
this.collapse(data.children)
}
} else {
this.$set(data, 'expand', true)
}
}
}
效果如下
点击节点
添加一个方法 on-node-click
<vue2-org-tree :data="data" :horizontal="true" collapsable @on-expand="onExpand" @on-node-click="onNodeHandle" />
...
onNodeHandle(e, data) {
// e是节点数据
console.log(e)
// data是渲染在节点上的数据
console.log(data)
},
已上为使用vue-tree-color组件实现组织架构图,接下来实现数据动态加载
数据动态加载
<template>
<div >
<vue2-org-tree :data="datas" @on-node-click="onNodeHandle" />
</div>
</template>
<script>
export default {
data () {
return {
datas:{
id:0,
label:'一级',
children:[
{
id:11,
label:'二级1'
}
]
}
}
},
methods: {
onNodeHandle(e, data) {
let newChild = [
{
id: 111,
label: '三级1'
},
{
id: 112,
label: '三级2'
},{
id: 113,
label: '三级3'
}
]
let targetNode = this.datas.children.find(node => node.id === 11);
if (targetNode) {
// 使用$set方法添加子节点
this.$set(targetNode, 'children', newChild); // 更新数据需要vue的响应式系统能捕获到
}
}
}
}
</script>
其中实现动态数据的加载关键在于确保数据更新是在 Vue 的响应式系统能够捕获到的情况下进行的。例如,如果数据是通过异步请求获取的,要确保在请求成功后,正确地更新treeData。如果在更新数据时,没有遵循 Vue 的响应式规则,比如直接修改数组的索引而不是使用 Vue 提供的数组变异方法(如push、splice等)或者ref、reactive的更新方法,组件可能无法正确更新。例如,不要这样更新数组this.treeData[0]=newValue(这不会触发响应式更新),而应该使用this.treeData.splice(0, 1, newValue)或者如果treeData是ref定义的,treeData.value.push(newValue)