关于在vue中实现组织架构树的方案

代码可能有部分错误,因为最终版代码搞丢了,复制粘贴请稍微改下,但一般能用

  1. 安装vue3-tree-org

npm insatll vue2-org-tree
  1. 在main.js引入文件

import vue3TreeOrg from 'vue3-tree-org';
import "vue3-tree-org/lib/vue3-tree-org.css";


Vue.use(vue3TreeOrg)

4.组件代码中复制该段,具体内容需要重写部分可以参照vue3-tree-org官方文档

<template>
 <vue3-tree-org
          :data="data"
          :collapsable="collapsable"
          :label-style="style"
          :only-one-node="onlyOneNode"
          :clone-node-drag="cloneNodeDrag"
          :before-drag-end="beforeDragEnd"
          @on-node-drag="nodeDragMove"
          @on-node-drag-end="nodeDragEnd"
          @on-contextmenu="onMenus"
          @on-expand="onExpand"
          @on-node-dblclick="onNodeDblclick"
          @on-node-click="onNodeClick"
        />
</template>

<script> 
export default{
data(){
    return{
      labelClassName: "bg-color-orange",
      basicInfo: { id: null, label: null },
      basicSwitch: false,
      data: {
        id: 0,
        label: "XXX科技有限公司",
        children: [
          {
            id: 2,
            label: "产品研发部",
            children: [
              {
                id: 5,
                label: "研发-前端",
                children: [
                  {
                    id: 55,
                    label: "前端1"
                  },
                  {
                    id: 56,
                    label: "前端2"
                  },
                  {
                    id: 57,
                    label: "前端3"
                  },
                  {
                    id: 58,
                    label: "前端4"
                  }
                ]
              },
              {
                id: 6,
                label: "研发-后端"
              },
              {
                id: 9,
                label: "UI设计"
              },
              {
                id: 10,
                label: "产品经理"
              }
            ]
          },
          {
            id: 3,
            label: "销售部",
            children: [
              {
                id: 7,
                label: "销售一部"
              },
              {
                id: 8,
                label: "销售二部"
              }
            ]
          },
          {
            id: 4,
            label: "财务部"
          },
          {
            id: 9,
            label: "HR人事"
          }
        ]
      },
    }
},
methods:{
    //渲染节点
     renderContent (h, data) {
      return (
        <div>
          <el-popover
            placement="bottom"
            trigger="click">
            <div style="text-align: right; margin: 0">
              <el-button size="mini" type="primary" plain round onClick={(v) => this.onClick(v, data)}>新增下级</el-button>
              <el-button size="mini" type="primary" plain round onClick={(v) => this.update(v, data)}>编辑</el-button>
              <el-button plain round size="mini" onClick={(v) => this.onerror(v, data)}>删除</el-button>
            </div>
            <div slot="reference">
              <div style="width:100%;height:100%;display:block;padding:12px 0 12px 10px;border-radius:3px;text-align:left;display:flex">
                <div style="height:9vh;" >
                
                </div>
                <div style="margin-left:10px;font-size:16px;">
                  <div style="font-weight: bold;">META PRINCIPAL</div>
                  <div style="border-bottom: 1px solid #ffffff;padding: 13px 0 4px 0;">{data.label}</div>
                  <div style="padding-top: 4px;">{data.label}</div>
                </div>
              </div>
            </div>
          </el-popover>
        </div>
      )
    },
    //鼠标移出
    onMouseout(e, data) {
      this.basicSwitch = false;
    },
    //鼠标移入
    onMouseover(e, data) {
      this.basicInfo = data;
      this.basicSwitch = true;
      // var floating = document.getElementsByClassName("floating")[0];
      // floating.style.left = e.clientX + "px";
      // floating.style.top = e.clientY + "px";
    },
    //点击节点
    NodeClick(e, data) {
      console.log(e, data);
    },
    rightClick (MouseEvent) {
      debugger
        console.log("鼠标右击事件",MouseEvent)
    },
    //默认展开
    toggleExpand(data, val) {
      if (Array.isArray(data)) {
        data.forEach(item => {
          this.$set(item, "expand", val);
          if (item.children) {
            this.toggleExpand(item.children, val);
          }
        });
      } else {
        this.$set(data, "expand", val);
        if (data.children) {
          this.toggleExpand(data.children, val);
        }
      }
    },
    collapse(list) {
      list.forEach(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);
      }
    },
}

}
</script>

<style>
.bg-gray {
    color: gray;
    box-shadow: none !important;
  }

.org-tree-container{
    position: relative;     /*定位*/
    top: 0;
    left: 0;
  }

</style>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
回答: 在Vue项目组织架构可以通过封装API接口来获取数据,并进行形处理。首先,需要在src/views/departments/index.vue文件引入组织架构模块的组件TreeTools。然后,在该文件可以使用el-tree组件来展示组织架构的内容。可以通过设置el-tree的data属性来传入组织架构的数据,通过设置defaultProps属性来指定显示内容的属性。同时,可以使用作用域插槽来循环展示每个节点的数据,并在插槽引入TreeTools组件实现对节点的操作。\[3\] 在获取组织架构数据时,可以封装API接口来获取数据。可以在src/views/departments/index.vue文件定义一个data属性来存储组织架构的数据。可以通过调用API接口来获取数据,并将获取到的数据赋值给data属性的departs。\[3\] 在进行形处理时,可以将获取到的数据转化成形结构。可以在src/views/departments/index.vue文件定义一个方法来实现将数组数据转化成形结构的功能。可以通过遍历数组数据,根据节点的父子关系来构建形结构。\[1\] 综上所述,在Vue项目,可以通过封装API接口来获取组织架构数据,并通过形处理将数据转化成形结构,然后在组织架构模块引入相应的组件来展示和操作组织架构的内容。 #### 引用[.reference_title] - *1* *2* *3* [Vue项目实战之人力资源平台系统(五)组织架构模块](https://blog.csdn.net/qq_40652101/article/details/126836202)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Robin let

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值