美文网首页
vue3 select-tree 部门+员工

vue3 select-tree 部门+员工

作者: 安徒生1997 | 来源:发表于2023-01-10 15:38 被阅读0次

1.效果图

2.html

<el-select

      v-model="state.users"

      value-key="value"

      placeholder="请选择"

      multiple

    collapse-tags

      collapse-tags-tooltip

      style="width: 240px"

      @visible-change="visibleChange"

      @remove-tag="removeTag">

      <el-option class="option" value="" />

      <el-tree

        class="admins-tree"

        :data="state.userList"

        ref="menuTree"

        :props="{

          value: 'departmentId',

          label: 'departmentName',

          children: 'child'

        }"

        node-key="departmentId"

        default-expand-all

        :expand-on-click-node="false">

        <template #default="{ data }">

          <div class="custom-tree-node">

            <div style="line-height: 30px">

              <el-icon class="icon mr5">

                <ele-Folder />

              </el-icon>

              <span @click="userClickcChild(data, 2)">{{ data.departmentName }}</span>

            </div>

            <div class="tree-div" v-show="data.userList?.length">

              <span

                class="texts"

                v-for="(item, index) in data.userList"

                :key="index"

                @click="userClickcChild(item, 1)"

                >{{ item.name }}</span

              >

            </div>

          </div>

        </template>

      </el-tree>

    </el-select>

2.js

const props = defineProps({

  // 0-部门/成员,1-成员

  isType: {

    type: Number,

    required: true,

    default: () => 0

  },

  // 是否多选 0-否,1-是

  isMany: {

    type: Number,

    required: true,

    default: () => 0

  },

  users: {

    type: Array as PropType<sadas[]>,

    required: true,

    default: () => []

  },

});

// 监听数组初始化格式

watch(() => props.users, () => {

  state.users = props.users.map((item: any) => {

    return {

      type: item.userId ? 1 : 2,

      value: item.userId ? item.userId : item.departmentId,

      label: item.name ? item.name : item.departmentName

    }

  })

},{deep: true});

//

const visibleChange = async (val: boolean) => {

  // console.log(val);

  if (val) {

    let res = await promotionApis.getDataListAndUser();

    // console.log(res.data);

    state.userList = res.data;

  }

};

// 成员点击

const emit = defineEmits(['update:users'])

// type: 1-人,2-部门

const userClickcChild = (rows: any, type: number) => {

  // console.log(rows)

  let status = {} as any

  if( type == 1 ) {

    status = props.users.find(( items: any ) => items.value == rows.userId)

  }

  if( type == 2 && props.isType != 1 ) {

    status = props.users.find(( items: any ) => items.value == rows.departmentId)

  }

  if( !status ) {

    if( props.isMany ) {

      state.users.push({

        type: type,

        value: rows.userId ? rows.userId : rows.departmentId,

        label: rows.userId ? rows.name : rows.departmentName

      })

    } else {

      state.users = [{

        type: type,

        value: rows.userId ? rows.userId : rows.departmentId,

        label: rows.userId ? rows.name : rows.departmentName

      }]

    }

  }

}

// 删除标签

const removeTag = (e: any) => {

  state.users.filter((item: any) => item.value == e.value)

}

相关文章

  • vue3 select-tree 部门+员工

    1.效果图 2.html

  • Javaweb笔记(十):多表查询小试牛刀(2)

    4. 列出部门名称和这些部门的员工信息,同时列出那些没有员工的部门。 列:部门名称 -> dept 员工信息>...

  • java 列转行

    一个员工在多个部门内,一个部门有多个员工List<员工> -----------> Map<...

  • 黑猴子的家:mysql 测试练习题

    1、显示员工表的每个部门的最大工资,工资平均值 2、查询部门的员工个数>5的部门编号和员工个数,并按员工个数降序 ...

  • SQL练习题-2

    员工表结构: 部门表结构: 部门员工表结构: 部门经理表结构: 薪资表结构: 1.获取所有员工当前的manager...

  • SQL练习题-1

    员工表结构: 部门表结构: 部门员工表结构: 部门经理表结构: 薪资表结构: 1.查找最晚入职员工的所有信息 分析...

  • SQL练习题-3

    员工表结构: 部门表结构: 部门员工表结构: 部门经理表结构: 薪资表结构: 1.查找所有员工自入职以来的薪水涨幅...

  • 多表查询练习

    显示所有员工的姓名,部门号和部门名称。 查询90号部门员工的job_id和90号部门的location_id 选择...

  • 18.多表查询练习

    查出至少有一个员工的部门。显示部门编号、部门名称、部门位置、部门人数。 列出所有员工的姓名及其直接上级的姓名 列出...

  • 2018-07-29全选案列

    员工信息列表 全选 员工编号 员工名称 员工部门 操作 ...

网友评论

      本文标题:vue3 select-tree 部门+员工

      本文链接:https://www.haomeiwen.com/subject/wrsvcdtx.html