VUE使用vue-tree-color组件实现组织架构图并可以动态更新数据的效果

 更新时间:2024年10月29日 14:27:20   作者:凌儿~  
本文主要介绍了如何在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组织架构图内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • vue如何在线预览各类型文件

    vue如何在线预览各类型文件

    这篇文章主要介绍了vue如何在线预览各类型文件问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-11-11
  • 基于Vue3实现无限滚动组件的示例代码

    基于Vue3实现无限滚动组件的示例代码

    如果你在社交媒体上停留的时间过长,那么,你所在的网站很可能正在使用无限滚动组件。这篇文章教你利用Vue3实现无限滚动组件,感兴趣的可以参考一下
    2022-09-09
  • 详解mpvue开发微信小程序基础知识

    详解mpvue开发微信小程序基础知识

    这篇文章主要介绍了详解mpvue开发微信小程序基础知识,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • 在Vue3项目中使用VueCropper裁剪组件实现裁剪及预览效果

    在Vue3项目中使用VueCropper裁剪组件实现裁剪及预览效果

    这篇文章主要介绍了在Vue3项目中使用VueCropper裁剪组件(裁剪及预览效果),本文分步骤结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-07-07
  • element-ui中的clickoutside点击空白隐藏元素

    element-ui中的clickoutside点击空白隐藏元素

    这篇文章主要为大家介绍了element-ui中的clickoutside点击空白隐藏元素示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-03-03
  • 使用Vue实现Markdown文档的展示和解析

    使用Vue实现Markdown文档的展示和解析

    在Vue项目中,Markdown文档的使用越来越普遍,因此在Vue中如何进行Markdown文档展示与解析也成为了一个热门话题,本文将介绍如何使用Vue实现Markdown文档的展示和解析,文中通过代码示例讲解的非常详细,需要的朋友可以参考下
    2024-01-01
  • 详解key在Vue3和Vue2的不同之处

    详解key在Vue3和Vue2的不同之处

    key属性是一个特殊的属性,用于标识每个节点的唯一性。在Vue2.x版本中的key和Vue3.x版本中的key有很大的不同,那么在这篇文章中,我们将会讨论Vue2中的key和Vue3中的key的区别
    2023-04-04
  • vue3使用百度地图超详细图文教程

    vue3使用百度地图超详细图文教程

    这篇文章主要给大家介绍了关于vue3使用百度地图的相关资料,最近一个项目要用到地图,因为微信小程序用的也是百度地图,所以想着网页端也用百度地图,需要的朋友可以参考下
    2023-07-07
  • Vue3源码解析watch函数实例

    Vue3源码解析watch函数实例

    这篇文章主要为大家介绍了Vue3源码解析watch函数实例解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • 彻底搞懂并解决vue-cli4中图片显示的问题实现

    彻底搞懂并解决vue-cli4中图片显示的问题实现

    这篇文章主要介绍了彻底搞懂并解决vue-cli4中图片显示的问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-08-08

最新评论