VUE使用vue-tree-color组件实现组织架构图并可以动态更新数据的效果
作者:凌儿~
本文主要介绍了如何在Vue中使用vue-tree-color组件实现组织架构图,并详细介绍了如何实现数据的动态加载,在动态加载数据时,要确保数据更新是在Vue的响应式系统能捕获到的情况下进行的
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)
动态数据效果图
到此这篇关于VUE使用vue-tree-color组件实现组织架构图并可以动态更新数据的效果的文章就介绍到这了,更多相关vue 使用vue-tree-color组织架构图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!