首页 > 其他分享 >HRM平台 - 组织结构的渲染

HRM平台 - 组织结构的渲染

时间:2022-11-09 01:11:36浏览次数:42  
标签:name 删除 渲染 treeData 平台 manager HRM 部门

组织结构是一个公司的灵魂 ,多使用树型结构 ;

页面格式:

 

 渲染头部 :

 

 头部代码:

<template>
  <el-row
    type="flex"
    justify="space-around"
    style="height: 40px; width: 100%"
    align="middle"
  >
    <!-- 左边 -->
    <el-col>{{ treeData.name }}</el-col>
    <!-- 右边 -->
    <el-col>
      <el-row type="flex" justify="end">
        <el-col :span="6">{{ treeData.manager }}</el-col>
        <el-col :span="6">
          <!-- 下拉菜单 -->
          <el-dropdown>
            <span class="el-dropdown-link">
              操作<i class="el-icon-arrow-down el-icon--right"></i>
            </span>
            <el-dropdown-menu slot="dropdown">
              <el-dropdown-item @click.native="$emit('addDept', treeData.id)">
                添加子部门
              </el-dropdown-item>
              <el-dropdown-item
                v-if="!isRoot"
                @click.native="$emit('editDept', treeData.id)"
              >
                编辑部门
              </el-dropdown-item>
              <el-dropdown-item v-if="!isRoot" @click.native="delRow">
                删除部门
              </el-dropdown-item>
            </el-dropdown-menu>
          </el-dropdown>
        </el-col>
      </el-row>
    </el-col>
  </el-row>
</template>

 

 

 

 

 将树型内容抽离成组件 tree-tool 

代码:

<template>
  <el-row
    type="flex"
    justify="space-around"
    style="height: 40px; width: 100%"
    align="middle"
  >
    <!-- 左边 -->
    <el-col>{{ treeData.name }}</el-col>
    <!-- 右边 -->
    <el-col>
      <el-row type="flex" justify="end">
        <el-col :span="6">{{ treeData.manager }}</el-col>
        <el-col :span="6">
          <!-- 下拉菜单 -->
          <el-dropdown>
            <span class="el-dropdown-link">
              操作<i class="el-icon-arrow-down el-icon--right"></i>
            </span>
            <el-dropdown-menu slot="dropdown">
              <el-dropdown-item @click.native="$emit('addDept', treeData.id)">
                添加子部门
              </el-dropdown-item>
              <el-dropdown-item
                v-if="!isRoot"
                @click.native="$emit('editDept', treeData.id)"
              >
                编辑部门
              </el-dropdown-item>
              <el-dropdown-item v-if="!isRoot" @click.native="delRow">
                删除部门
              </el-dropdown-item>
            </el-dropdown-menu>
          </el-dropdown>
        </el-col>
      </el-row>
    </el-col>
  </el-row>
</template>
<script>
import { delDepartmentApi } from "@/api/department";
export default {
  name: "TreeTools",
  props: {
    // 是否根节点
    isRoot: {
      type: Boolean,
      default: false,
    },
    // 工具条的数据
    treeData: {
      type: Object, // { name:'xxx', magager:'xx' }
      required: true,
    },
  },
  methods: {
    // 删除当前行的数据
    async delRow() {
      // 1.提示确认框
      try {
        await this.$confirm("确认删除吗?");
      } catch (error) {
        return console.log(error);
      }
      // 2. 发生删除请求
      await delDepartmentApi(this.treeData.id);
      // 3. 失败处理
      // 4. 成功处理
      this.$message.success("删除成功");
      this.$emit("updateList");
    },
  },
};
</script>
<style></style>

 

标签:name,删除,渲染,treeData,平台,manager,HRM,部门
From: https://www.cnblogs.com/zhulongxu/p/16871840.html

相关文章