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)

动态数据效果图

在这里插入图片描述

### 实现点击树节点高亮显示 为了实现在 `vue2-org-tree` 中点击节点时高亮显示的效果,可以利用组件提供的事件处理机制以及自定义样式来完成这一功能。具体来说,在模板部分绑定 `@node-click` 事件监听器,在方法中更新当前选中的节点状态。 #### 组件安装与引入 首先按照官方指南通过 npm 或 yarn 安装依赖包: ```bash npm install vue2-org-tree --save # or yarn add vue2-org-tree ``` 接着在项目文件里导入注册该组件[^1]。 #### HTML 模板配置 在 Vue 单文件组件 (SFC) 的 `<template>` 部分添加如下代码片段用于渲染组织架构图指定必要的属性如数据源 (`:data`) 和配置项 (`:config`) 同时绑定了点击事件处理器(`@node-click="onNodeClick"`): ```html <org-chart :datasource="dataSource" :config="chartConfig" @node-click="onNodeClick"> </org-chart> ``` #### JavaScript 方法编写 接下来是在 `<script>` 块内定义响应函数 `onNodeClick`, 当用户单击某个特定节点触发此回调函数后改变其对应的激活状态变量 `activeNodeId`. 这样就可以控制哪个节点处于被选中即高亮的状态: ```javascript import OrgChart from 'vue2-org-tree'; export default { name: "TreeComponent", components: {OrgChart}, data() { return { activeNodeId: null, dataSource: {...}, // 数据集 chartConfig: {...} // 图表配置参数 } }, methods:{ onNodeClick(node){ this.activeNodeId = node.id; } } } ``` #### CSS 样式调整 最后一步是修改或新增一些CSS类名以确保当某节点成为活动对象时能够应用不同的视觉效果比如背景颜色变化等。可以在全局样式文件或者局部 scoped style 下面加入下面这段规则: ```css .node-active{ background-color:#d9edf7 !important; border-left:4px solid blue!important; } ``` 同时还需要确保所使用的版本支持上述特性,且正确设置了相应的 class 名字给目标 DOM 元素以便于匹配上这些额外的样式声明。 综上所述,通过以上几个方面的设置就能很好地满足对于 `vue2-org-tree` 插件实现点击节点高亮的需求了。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值