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)
动态数据效果图
到此这篇关于VUE使用vue-tree-color组件实现组织架构图并可以动态更新数据的效果的文章就介绍到这了,更多相关vue 使用vue-tree-color组织架构图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue3+Element Plus实现动态标签页以及右键菜单功能
这篇文章主要给大家介绍了关于Vue3+Element Plus实现动态标签页以及右键菜单功能的相关资料,Vue 3和Element Plus提供了一种简单的方法来实现侧边菜单栏与标签页之间的联动,文中通过代码介绍的非常详细,需要的朋友可以参考下2023-09-09vue静态配置文件不进行编译的处理过程(在public中引入js)
这篇文章主要介绍了vue静态配置文件不进行编译的处理过程(在public中引入js),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-03-03解决报错ValidationError: Progress Plugin Invalid&
这篇文章主要介绍了解决报错ValidationError: Progress Plugin Invalid Options问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2023-11-11
最新评论