基于ElementUI封装的下拉树选择可搜索单选多选清空功能

发布时间:2024年01月03日

效果:

基于ElementUI封装的下拉树选择可搜索单选多选清空功能

组件代码

/**
  * 树形下拉选择组件,下拉框展示树形结构,提供选择某节点功能,方便其他模块调用
  * @author wy
  * @date 2024-01-03  * 调用示例:
  * <tree-select 
  * :height="400" // 下拉框中树形高度
  *     :width="200" // 下拉框中树形宽度
  *     :isFilter="true" //是否出现树结构搜索过滤
  *     size="small"  // 输入框的尺寸: medium/small/mini
  *     :data="data" // 树结构的数据
  *     :defaultProps="defaultProps" // 树结构的props
  *     multiple   // 多选
  *     :inputWidth='250'  //输入框的长度 Number
  *     clearable   // 可清空选择
  *     collapseTags   // 多选时将选中值按文字的形式展示
  *     checkStrictly // 多选时,严格遵循父子不互相关联
  *     :nodeKey="nodeKey"   // 绑定nodeKey,默认绑定'id'
  *     :checkedKeys="defaultCheckedKeys"  // 传递默认选中的节点key组成的数组
  *     @popoverHide="popoverHide"> // 事件有两个参数:第一个是所有选中的节点ID,第二个是所有选中的节点数据
  *  </tree-select>
*/
<template>
  <div>
    <div
      v-show="isShowSelect"
      class="mask"
      @click="isShowSelect = !isShowSelect"
    />
    <el-popover
      v-model="isShowSelect"
      placement="bottom-start"
      :width="width"
      trigger="manual"
      style="padding: 12px 0"
      @hide="popoverHide"
    >
      <el-input v-if="isFilter" placeholder="输入关键字进行过滤" size="mini" v-model="filterText">
      </el-input>
      <el-tree
        ref="tree"
        class="common-tree"
        :style="style"
        :data="data"
        :props="defaultProps"
        :show-checkbox="multiple"
        :node-key="nodeKey"
        :check-strictly="checkStrictly"
        default-expand-all
        :filter-node-method="filterNode"
        :expand-on-click-node="false"
        :check-on-click-node="multiple"
        :highlight-current="true"
        @node-click="handleNodeClick"
        @check-change="handleCheckChange"
      />
      <el-select
        slot="reference"
        ref="select"
        v-model="selectedData"
        :style="selectStyle"
        :size="size"
        :multiple="multiple"
        :clearable="clearable"
        :collapse-tags="collapseTags"
        class="tree-select"
        @click.native="isShowSelect = !isShowSelect"
        @remove-tag="removeSelectedNodes"
        @clear="removeSelectedNode"
        @change="changeSelectedNodes"
      >
        <el-option
          v-for="item in options"
          :key="item.value"
          :label="item.label"
          :value="item.value"
        />
      </el-select>
    </el-popover>
  </div>
</template>

<script>
export default {
  props: {
    // 树结构数据
    data: {
      type: Array,
      default() {
        return [];
      },
    },
    defaultProps: {
      type: Object,
      default() {
        return {
          children: "children",
          label: "name",
        };
      },
    },
    // 配置是否可多选
    multiple: {
      type: Boolean,
      default() {
        return false;
      },
    },
    // 配置是否可清空选择
    clearable: {
      type: Boolean,
      default() {
        return false;
      },
    },
    // 配置多选时是否将选中值按文字的形式展示
    collapseTags: {
      type: Boolean,
      default() {
        return false;
      },
    },
    //唯一key值
    nodeKey: {
      type: String,
      default() {
        return "id";
      },
    },
    // 显示复选框情况下,是否严格遵循父子不互相关联
    checkStrictly: {
      type: Boolean,
      default() {
        return false;
      },
    },
    // 默认选中的节点key数组
    checkedKeys: {
      type: Array,
      default() {
        return [];
      },
    },
    // 输入框的尺寸
    size: {
      type: String,
      default() {
        return "medium";
      },
    },
    // 总体宽度
    width: {
      type: Number,
      default() {
        return 250;
      },
    },
    // 输入框的宽度
    inputWidth: {
      type: Number,
      default() {
        return 150;
      },
    },
    // 下拉框的高度
    height: {
      type: Number,
      default() {
        return 300;
      },
    },
    // 是否具有过滤搜索功能
    isFilter: {
      type: Boolean,
      default() {
        return true;
      },
    },
  },
  data() {
    return {
      filterText: "", //树搜索
      isShowSelect: false, // 是否显示树状选择器
      options: [],
      selectedData: [], // 选中的节点
      style: "width:" + this.width + "px;" + "height:" + this.height + "px;",
      selectStyle: "width:" + this.inputWidth + "px;",
      checkedIds: [],
      checkedData: [],
    };
  },
  watch: {
    filterText(val) {
      this.$refs.tree.filter(val);
    },
    // eslint-disable-next-line no-unused-vars
    isShowSelect(val) {
      // 隐藏select自带的下拉框
      this.$refs.select.blur();
    },
    checkedKeys(val) {
      console.log("checkedKeys", val);
      if (!val) return;
      // eslint-disable-next-line vue/no-mutating-props
      this.checkedKeys = val;
      this.initCheckedData();
    },
  },
  mounted() {
    this.initCheckedData();
  },
  methods: {
    //过滤函数
    filterNode(value, data) {
      if (!value) return true;
      return data[this.defaultProps.label].indexOf(value) !== -1;
    },
    // 单选时点击tree节点,设置select选项
    setSelectOption(node) {
      // console.log("~~~~~",node)
      const tmpMap = {};
      tmpMap.value = node.key;
      tmpMap.label = node.label;
      this.options = [];
      this.options.push(tmpMap);
      this.selectedData = node.key;
    },
    // 单选,选中传进来的节点
    checkSelectedNode(checkedKeys) {
      var item = checkedKeys[0];
      this.$refs.tree.setCurrentKey(item);
      var node = this.$refs.tree.getNode(item);
      // console.log("checkSelectedNode",this.$refs.tree)
      this.setSelectOption(node);
    },
    // 多选,勾选上传进来的节点
    checkSelectedNodes(checkedKeys) {
      // this.$refs.tree.setCheckedKeys(checkedKeys)
      // console.log("checkSelectedNodes-checkedKeys",checkedKeys)
      // 优化select回显显示 有个延迟的效果
      const that = this;
      setTimeout(function () {
        that.$refs.tree.setCheckedKeys(checkedKeys);
      }, 10);
      this.$forceUpdate();
      // console.log('checkSelectedNodes', this.selectedData)
    },
    // 单选,清空选中
    clearSelectedNode() {
      this.selectedData = [];
      this.$refs.tree.setCurrentKey(null);
    },
    // 多选,清空所有勾选
    clearSelectedNodes() {
      var checkedKeys = this.$refs.tree.getCheckedKeys(); // 所有被选中的节点的 key 所组成的数组数据
      for (let i = 0; i < checkedKeys.length; i++) {
        this.$refs.tree.setChecked(checkedKeys[i], false);
      }
    },
    // 在组件初始化时,根据传递的默认选中节点信息,设置树形结构中的节点的选中状态。
    initCheckedData() {
      if (this.multiple) {
        // 多选
        // console.log(this.checkedKeys.length)
        if (this.checkedKeys.length > 0) {
          this.checkSelectedNodes(this.checkedKeys);
        } else {
          this.clearSelectedNodes();
        }
      } else {
        // 单选
        if (this.checkedKeys.length > 0) {
          this.checkSelectedNode(this.checkedKeys);
        } else {
          this.clearSelectedNode();
        }
      }
    },
    popoverHide() {
      if (this.multiple) {
        this.checkedIds = this.$refs.tree.getCheckedKeys(); // 所有被选中的节点的 key 所组成的数组数据
        this.checkedData = this.$refs.tree.getCheckedNodes(); // 所有被选中的节点所组成的数组数据
      } else {
        this.checkedIds = this.$refs.tree.getCurrentKey();
        this.checkedData = this.$refs.tree.getCurrentNode();
      }
      this.$emit("popoverHide", this.checkedIds, this.checkedData);
    },
    // 单选,节点被点击时的回调,返回被点击的节点数据
    handleNodeClick(data, node) {
      if (!this.multiple) {
        this.setSelectOption(node);
        this.isShowSelect = !this.isShowSelect;
        this.$emit("change", this.selectedData);
      }
    },
    // 多选,节点勾选状态发生变化时的回调
    handleCheckChange() {
      var checkedKeys = this.$refs.tree.getCheckedKeys(); // 所有被选中的节点的 key 所组成的数组数据
      this.options = checkedKeys.map((item) => {
        var node = this.$refs.tree.getNode(item); // 所有被选中的节点对应的node
        const tmpMap = {};
        tmpMap.value = node.key;
        tmpMap.label = node.label;
        return tmpMap;
      });
      this.selectedData = this.options.map((item) => {
        return item.value;
      });
      this.$emit("change", this.selectedData);
    },
    // 多选,删除任一select选项的回调
    removeSelectedNodes(val) {
      this.$refs.tree.setChecked(val, false);
      var node = this.$refs.tree.getNode(val);
      if (!this.checkStrictly && node.childNodes.length > 0) {
        this.treeToList(node).map((item) => {
          if (item.childNodes.length <= 0) {
            this.$refs.tree.setChecked(item, false);
          }
        });
        this.handleCheckChange();
      }
      this.$emit("change", this.selectedData);
    },
    treeToList(tree) {
      var queen = [];
      var out = [];
      queen = queen.concat(tree);
      while (queen.length) {
        var first = queen.shift();
        if (first.childNodes) {
          queen = queen.concat(first.childNodes);
        }
        out.push(first);
      }
      return out;
    },
    // 单选,清空select输入框的回调
    removeSelectedNode() {
      this.clearSelectedNode();
      this.$emit("change", this.selectedData);
    },
    // 选中的select选项改变的回调
    changeSelectedNodes(selectedData) {
      // 多选,清空select输入框时,清除树勾选
      if (this.multiple && selectedData.length <= 0) {
        this.clearSelectedNodes();
      }
      this.$emit("change", this.selectedData);
    },
  },
};
</script>
<style scoped>
.mask {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  opacity: 0;
  z-index: 11;
}

.common-tree {
  overflow: auto;
}

.tree-select {
  z-index: 111;
}
</style>

参数方法说明

属性说明
height下拉框中树形高度 height=“400”
width下拉框中树形宽度 width =“400”
isFilter是否出现树结构搜索过滤 默认为true
size输入框的尺寸: medium/small/mini
data树结构的数据
defaultProps树结构的props,树结构说明
multiple是否多选
inputWidth输入框的长度 Number
clearable是否可清空选择
collapseTags多选时将选中值按文字的形式展示
checkStrictly多选时,严格遵循父子不互相关联
nodeKey绑定nodeKey,默认绑定’id’
checkedKeys传递默认选中的节点key组成的数组
@popoverHide=“popoverHide”事件有两个参数:第一个是所有选中的节点ID,第二个是所有选中的节点数据
@change=“clearKey”当选项改变时触发

组件使用包含模拟数据

<template>
  <div>
    <HSKselecte
      v-model="workName"
      :inputWidth="250"
      :data="treeData"
      v-show="dialogFormVisible"
      style="'width: 100%'"
      :checkedKeys="defaultCheckedKeys"
      @change="clearKey"
      :isFilter="isFilter"
      clearable
      :multiple="multiple"
      @popoverHide="onCateSelect"
    >
    </HSKselecte>
  </div>
</template>
<script>
// import selectTree from "@/package/hsk-treeSelect/index.vue";
import HSKselecte from "../package/hsk-treeSelect/index.vue";
export default {
  data() {
    return {
      isFilter:true,
      multiple:true,
      radio1:'',
      workName:'',
      dialogFormVisible: true,
      selectType: "sigle",
      defaultCheckedKeys: [],
      defaultExpandedKeys: [],
      checkedKeys: [],
      treeData: [
        {
          id: "platform-1651478710725455875",
          parentId: null,
          name: "基础信息",
          identification: null,
          url: null,
          sortNo: null,
          menuType: "0",
          permissionGroupId: null,
          checkFlag: null,
          platformId: null,
          children: [
            {
              id: "1",
              parentId: "0",
              name: "生产单位管理",
              identification: null,
              url: "/workUnit",
              sortNo: "1",
              menuType: "1",
              permissionGroupId: null,
              checkFlag: true,
              platformId: "1651478710725455875",
              children: [
                {
                  id: "6",
                  parentId: "1",
                  name: "生产单位",
                  identification: null,
                  url: "workUnit",
                  sortNo: "1",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "pagInfo-1",
                      parentId: "6",
                      name: "车间管理",
                      identification: null,
                      url: null,
                      sortNo: null,
                      menuType: "3",
                      permissionGroupId: null,
                      checkFlag: null,
                      platformId: null,
                      children: [
                        {
                          id: "17",
                          parentId: "pagInfo-1",
                          name: "新增",
                          identification:
                            "basic:productionUnitManagement:productionUnit:addworkshop",
                          url: null,
                          sortNo: "1",
                          menuType: "4",
                          permissionGroupId: "1",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "18",
                          parentId: "pagInfo-1",
                          name: "修改",
                          identification:
                            "basic:productionUnitManagement:productionUnit:editshop",
                          url: null,
                          sortNo: "2",
                          menuType: "4",
                          permissionGroupId: "1",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "19",
                          parentId: "pagInfo-1",
                          name: "删除",
                          identification:
                            "basic:productionUnitManagement:productionUnit:deleteshop",
                          url: null,
                          sortNo: "3",
                          menuType: "4",
                          permissionGroupId: "1",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "20",
                          parentId: "pagInfo-1",
                          name: "设置状态",
                          identification:
                            "basic:productionUnitManagement:productionUnit:editshopstatus",
                          url: null,
                          sortNo: "4",
                          menuType: "4",
                          permissionGroupId: "1",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                      ],
                    },
                    {
                      id: "pagInfo-2",
                      parentId: "6",
                      name: "工作中心管理",
                      identification: null,
                      url: null,
                      sortNo: null,
                      menuType: "3",
                      permissionGroupId: null,
                      checkFlag: null,
                      platformId: null,
                      children: [
                        {
                          id: "21",
                          parentId: "pagInfo-2",
                          name: "新增",
                          identification:
                            "basic:productionUnitManagement:productionUnit:addworkcenter",
                          url: null,
                          sortNo: "5",
                          menuType: "4",
                          permissionGroupId: "2",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "22",
                          parentId: "pagInfo-2",
                          name: "修改",
                          identification:
                            "basic:productionUnitManagement:productionUnit:editworkcenter",
                          url: null,
                          sortNo: "6",
                          menuType: "4",
                          permissionGroupId: "2",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "23",
                          parentId: "pagInfo-2",
                          name: "删除",
                          identification:
                            "basic:productionUnitManagement:productionUnit:deleteworkcenter",
                          url: null,
                          sortNo: "7",
                          menuType: "4",
                          permissionGroupId: "2",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "24",
                          parentId: "pagInfo-2",
                          name: "设置状态",
                          identification:
                            "basic:productionUnitManagement:productionUnit:editworkcenterstatus",
                          url: null,
                          sortNo: "8",
                          menuType: "4",
                          permissionGroupId: "2",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                      ],
                    },
                    {
                      id: "pagInfo-3",
                      parentId: "6",
                      name: "产线管理",
                      identification: null,
                      url: null,
                      sortNo: null,
                      menuType: "3",
                      permissionGroupId: null,
                      checkFlag: null,
                      platformId: null,
                      children: [
                        {
                          id: "25",
                          parentId: "pagInfo-3",
                          name: "新增",
                          identification:
                            "basic:productionUnitManagement:productionUnit:addproductionline",
                          url: null,
                          sortNo: "9",
                          menuType: "4",
                          permissionGroupId: "3",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "26",
                          parentId: "pagInfo-3",
                          name: "修改",
                          identification:
                            "basic:productionUnitManagement:productionUnit:editproductionline",
                          url: null,
                          sortNo: "10",
                          menuType: "4",
                          permissionGroupId: "3",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "27",
                          parentId: "pagInfo-3",
                          name: "删除",
                          identification:
                            "basic:productionUnitManagement:productionUnit:deleteproductionline",
                          url: null,
                          sortNo: "11",
                          menuType: "4",
                          permissionGroupId: "3",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "28",
                          parentId: "pagInfo-3",
                          name: "设置状态",
                          identification:
                            "basic:productionUnitManagement:productionUnit:editproductionlinestatus",
                          url: null,
                          sortNo: "12",
                          menuType: "4",
                          permissionGroupId: "3",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                      ],
                    },
                    {
                      id: "pagInfo-4",
                      parentId: "6",
                      name: "设备管理",
                      identification: null,
                      url: null,
                      sortNo: null,
                      menuType: "3",
                      permissionGroupId: null,
                      checkFlag: null,
                      platformId: null,
                      children: [
                        {
                          id: "29",
                          parentId: "pagInfo-4",
                          name: "绑定",
                          identification:
                            "basic:productionUnitManagement:productionUnit:bindequipment",
                          url: null,
                          sortNo: "13",
                          menuType: "4",
                          permissionGroupId: "4",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "30",
                          parentId: "pagInfo-4",
                          name: "解绑",
                          identification:
                            "basic:productionUnitManagement:productionUnit:unbindequipment",
                          url: null,
                          sortNo: "14",
                          menuType: "4",
                          permissionGroupId: "4",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                      ],
                    },
                  ],
                },
                {
                  id: "7",
                  parentId: "1",
                  name: "设备保养计划",
                  identification: null,
                  url: "maintenancePlan",
                  sortNo: "2",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "31",
                      parentId: "7",
                      name: "新增",
                      identification:
                        "basic:productionUnitManagement:maintenancePlan:addPlan",
                      url: null,
                      sortNo: "1",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "32",
                      parentId: "7",
                      name: "修改",
                      identification:
                        "basic:productionUnitManagement:maintenancePlan:editPlan",
                      url: null,
                      sortNo: "2",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "33",
                      parentId: "7",
                      name: "删除",
                      identification:
                        "basic:productionUnitManagement:maintenancePlan:deletePlan",
                      url: null,
                      sortNo: "3",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "39",
                      parentId: "7",
                      name: "导入模板",
                      identification:
                        "basic:productionUnitManagement:maintenancePlan:importPlan",
                      url: null,
                      sortNo: "5",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "97",
                      parentId: "7",
                      name: "查看详情",
                      identification:
                        "basic:productionUnitManagement:maintenancePlan:detailPlan",
                      url: null,
                      sortNo: "6",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                  ],
                },
                {
                  id: "8",
                  parentId: "1",
                  name: "设备管理",
                  identification: null,
                  url: "equipment",
                  sortNo: "3",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "34",
                      parentId: "8",
                      name: "新增",
                      identification:
                        "basic:productionUnitManagement:equipmentUnit:addequipment",
                      url: null,
                      sortNo: "1",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "35",
                      parentId: "8",
                      name: "修改",
                      identification:
                        "basic:productionUnitManagement:equipmentUnit:editequipment",
                      url: null,
                      sortNo: "2",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "36",
                      parentId: "8",
                      name: "删除",
                      identification:
                        "basic:productionUnitManagement:equipmentUnit:deleteequipment",
                      url: null,
                      sortNo: "3",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "37",
                      parentId: "8",
                      name: "设置状态",
                      identification:
                        "basic:productionUnitManagement:equipmentUnit:editequipmentstatus",
                      url: null,
                      sortNo: "4",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "41",
                      parentId: "8",
                      name: "导入模板",
                      identification:
                        "basic:productionUnitManagement:equipmentUnit:importtemplate",
                      url: null,
                      sortNo: "6",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                  ],
                },
              ],
            },
            {
              id: "2",
              parentId: "0",
              name: "用户权限管理",
              identification: null,
              url: "/user",
              sortNo: "2",
              menuType: "1",
              permissionGroupId: null,
              checkFlag: true,
              platformId: "1651478710725455875",
              children: [
                {
                  id: "9",
                  parentId: "2",
                  name: "用户管理",
                  identification: null,
                  url: "user",
                  sortNo: "1",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "pagInfo-5",
                      parentId: "9",
                      name: "部门管理",
                      identification: null,
                      url: null,
                      sortNo: null,
                      menuType: "3",
                      permissionGroupId: null,
                      checkFlag: null,
                      platformId: null,
                      children: [
                        {
                          id: "42",
                          parentId: "pagInfo-5",
                          name: "新增",
                          identification: "basic:userManage:depart:addDept",
                          url: null,
                          sortNo: "1",
                          menuType: "4",
                          permissionGroupId: "5",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "43",
                          parentId: "pagInfo-5",
                          name: "修改",
                          identification: "basic:userManage:depart:editDept",
                          url: null,
                          sortNo: "2",
                          menuType: "4",
                          permissionGroupId: "5",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "44",
                          parentId: "pagInfo-5",
                          name: "删除",
                          identification: "basic:userManage:depart:deleteDept",
                          url: null,
                          sortNo: "3",
                          menuType: "4",
                          permissionGroupId: "5",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                      ],
                    },
                    {
                      id: "pagInfo-6",
                      parentId: "9",
                      name: "用户管理",
                      identification: null,
                      url: null,
                      sortNo: null,
                      menuType: "3",
                      permissionGroupId: null,
                      checkFlag: null,
                      platformId: null,
                      children: [
                        {
                          id: "45",
                          parentId: "pagInfo-6",
                          name: "新增",
                          identification: "basic:userManage:user:adduser",
                          url: null,
                          sortNo: "4",
                          menuType: "4",
                          permissionGroupId: "6",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "46",
                          parentId: "pagInfo-6",
                          name: "修改",
                          identification: "basic:userManage:user:edituser",
                          url: null,
                          sortNo: "5",
                          menuType: "4",
                          permissionGroupId: "6",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "47",
                          parentId: "pagInfo-6",
                          name: "删除",
                          identification: "basic:userManage:user:deleteuser",
                          url: null,
                          sortNo: "6",
                          menuType: "4",
                          permissionGroupId: "6",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "48",
                          parentId: "pagInfo-6",
                          name: "设置状态",
                          identification:
                            "basic:userManage:user:edituserstatus",
                          url: null,
                          sortNo: "7",
                          menuType: "4",
                          permissionGroupId: "6",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "49",
                          parentId: "pagInfo-6",
                          name: "分配角色",
                          identification: "basic:userManage:user:assignroles",
                          url: null,
                          sortNo: "8",
                          menuType: "4",
                          permissionGroupId: "6",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "50",
                          parentId: "pagInfo-6",
                          name: "重置密码",
                          identification: "basic:userManage:user:userrepaw",
                          url: null,
                          sortNo: "9",
                          menuType: "4",
                          permissionGroupId: "6",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "52",
                          parentId: "pagInfo-6",
                          name: "导入模板",
                          identification:
                            "basic:userManage:user:importtemplate",
                          url: null,
                          sortNo: "11",
                          menuType: "4",
                          permissionGroupId: "6",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                      ],
                    },
                  ],
                },
                {
                  id: "10",
                  parentId: "2",
                  name: "角色管理",
                  identification: null,
                  url: "role",
                  sortNo: "2",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "53",
                      parentId: "10",
                      name: "分配权限",
                      identification: "basic:roleManage:role:assignauthority",
                      url: null,
                      sortNo: "1",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "54",
                      parentId: "10",
                      name: "新增",
                      identification: "basic:roleManage:role:addrole",
                      url: null,
                      sortNo: "2",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "55",
                      parentId: "10",
                      name: "修改",
                      identification: "basic:roleManage:role:editrole",
                      url: null,
                      sortNo: "3",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "56",
                      parentId: "10",
                      name: "删除",
                      identification: "basic:roleManage:role:deleterole",
                      url: null,
                      sortNo: "4",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                  ],
                },
              ],
            },
            {
              id: "3",
              parentId: "0",
              name: "生产物料管理",
              identification: null,
              url: "/material",
              sortNo: "3",
              menuType: "1",
              permissionGroupId: null,
              checkFlag: true,
              platformId: "1651478710725455875",
              children: [
                {
                  id: "11",
                  parentId: "3",
                  name: "物料管理",
                  identification: null,
                  url: "material",
                  sortNo: "1",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "57",
                      parentId: "11",
                      name: "新增",
                      identification:
                        "basic:materialUnitManagement:materialUnit:addmaterial",
                      url: null,
                      sortNo: "1",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "58",
                      parentId: "11",
                      name: "修改",
                      identification:
                        "basic:materialUnitManagement:materialUnit:editmaterial",
                      url: null,
                      sortNo: "2",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "59",
                      parentId: "11",
                      name: "删除",
                      identification:
                        "basic:materialUnitManagement:materialUnit:deletematerial",
                      url: null,
                      sortNo: "3",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "61",
                      parentId: "11",
                      name: "导入模板",
                      identification:
                        "basic:materialUnitManagement:materialUnit:importmaterial",
                      url: null,
                      sortNo: "5",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "62",
                      parentId: "11",
                      name: "导出",
                      identification:
                        "basic:materialUnitManagement:materialUnit:exportmaterial",
                      url: null,
                      sortNo: "6",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "98",
                      parentId: "11",
                      name: "新增bom",
                      identification:
                        "basic:materialUnitManagement:bomUnit:addbom",
                      url: null,
                      sortNo: "7",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "99",
                      parentId: "11",
                      name: "修改bom",
                      identification:
                        "basic:materialUnitManagement:bomUnit:editbom",
                      url: null,
                      sortNo: "8",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "100",
                      parentId: "11",
                      name: "新增工艺路线",
                      identification:
                        "basic:materialUnitManagement:processrouteUnit:addprocessroute",
                      url: null,
                      sortNo: "9",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "101",
                      parentId: "11",
                      name: "修改工艺路线",
                      identification:
                        "basic:materialUnitManagement:processrouteUnit:editprocessroute",
                      url: null,
                      sortNo: "10",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                  ],
                },
                {
                  id: "12",
                  parentId: "3",
                  name: "BOM管理",
                  identification: null,
                  url: "bom",
                  sortNo: "2",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "63",
                      parentId: "12",
                      name: "新增",
                      identification:
                        "basic:materialUnitManagement:bomUnit:addbom",
                      url: null,
                      sortNo: "1",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "64",
                      parentId: "12",
                      name: "修改",
                      identification:
                        "basic:materialUnitManagement:bomUnit:editbom",
                      url: null,
                      sortNo: "2",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "65",
                      parentId: "12",
                      name: "删除",
                      identification:
                        "basic:materialUnitManagement:bomUnit:deletebom",
                      url: null,
                      sortNo: "3",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "67",
                      parentId: "12",
                      name: "导入模板",
                      identification:
                        "basic:materialUnitManagement:bomUnit:importbom",
                      url: null,
                      sortNo: "5",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "68",
                      parentId: "12",
                      name: "设置状态",
                      identification:
                        "basic:materialUnitManagement:bomUnit:editbomstatus",
                      url: null,
                      sortNo: "6",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                  ],
                },
                {
                  id: "13",
                  parentId: "3",
                  name: "工艺路线管理",
                  identification: null,
                  url: "processRoute",
                  sortNo: "3",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "69",
                      parentId: "13",
                      name: "新增",
                      identification:
                        "basic:materialUnitManagement:processrouteUnit:addprocessroute",
                      url: null,
                      sortNo: "1",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "70",
                      parentId: "13",
                      name: "修改",
                      identification:
                        "basic:materialUnitManagement:processrouteUnit:editprocessroute",
                      url: null,
                      sortNo: "2",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "71",
                      parentId: "13",
                      name: "删除",
                      identification:
                        "basic:materialUnitManagement:processrouteUnit:deleteprocessroute",
                      url: null,
                      sortNo: "3",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "72",
                      parentId: "13",
                      name: "设置状态",
                      identification:
                        "basic:materialUnitManagement:processrouteUnit:editprocessroutestatus",
                      url: null,
                      sortNo: "4",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "74",
                      parentId: "13",
                      name: "导入模板",
                      identification:
                        "basic:materialUnitManagement:processrouteUnit:importprocessroute",
                      url: null,
                      sortNo: "6",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                  ],
                },
                {
                  id: "14",
                  parentId: "3",
                  name: "工艺管理",
                  identification: null,
                  url: "technology",
                  sortNo: "4",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "75",
                      parentId: "14",
                      name: "新增",
                      identification: "basic:technologyManage:technology:add",
                      url: null,
                      sortNo: "1",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "76",
                      parentId: "14",
                      name: "修改",
                      identification: "basic:technologyManage:technology:edit",
                      url: null,
                      sortNo: "2",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "77",
                      parentId: "14",
                      name: "删除",
                      identification:
                        "basic:technologyManage:technology:delete",
                      url: null,
                      sortNo: "3",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "78",
                      parentId: "14",
                      name: "设置状态",
                      identification:
                        "basic:technologyManage:technology:edittechnologystatus",
                      url: null,
                      sortNo: "4",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "80",
                      parentId: "14",
                      name: "导入模板",
                      identification:
                        "basic:technologyManage:technology:importtemplate",
                      url: null,
                      sortNo: "6",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                  ],
                },
              ],
            },
            {
              id: "4",
              parentId: "0",
              name: "生产日历管理",
              identification: null,
              url: "/calendar",
              sortNo: "4",
              menuType: "1",
              permissionGroupId: null,
              checkFlag: true,
              platformId: "1651478710725455875",
              children: [
                {
                  id: "15",
                  parentId: "4",
                  name: "工作日历",
                  identification: null,
                  url: "calendar",
                  sortNo: "1",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "81",
                      parentId: "15",
                      name: "新增",
                      identification:
                        "basic:calendarUnitManagement:calendarUnit:addcalendar",
                      url: null,
                      sortNo: "1",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "82",
                      parentId: "15",
                      name: "修改",
                      identification:
                        "basic:calendarUnitManagement:calendarUnit:editcalendar",
                      url: null,
                      sortNo: "2",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "83",
                      parentId: "15",
                      name: "删除",
                      identification:
                        "basic:calendarUnitManagement:calendarUnit:deletecalendar",
                      url: null,
                      sortNo: "3",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "84",
                      parentId: "15",
                      name: "配置班次",
                      identification:
                        "basic:calendarUnitManagement:calendarUnit:configclassforcalendar",
                      url: null,
                      sortNo: "4",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                  ],
                },
                {
                  id: "16",
                  parentId: "4",
                  name: "班次管理",
                  identification: null,
                  url: "scheduling",
                  sortNo: "2",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "85",
                      parentId: "16",
                      name: "新增",
                      identification:
                        "basic:calendarUnitManagement:scheduleUnit:addschedule",
                      url: null,
                      sortNo: "1",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "86",
                      parentId: "16",
                      name: "修改",
                      identification:
                        "basic:calendarUnitManagement:scheduleUnit:editschedule",
                      url: null,
                      sortNo: "2",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "87",
                      parentId: "16",
                      name: "删除",
                      identification:
                        "basic:calendarUnitManagement:scheduleUnit:deleteschedule",
                      url: null,
                      sortNo: "3",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "88",
                      parentId: "16",
                      name: "设置状态",
                      identification:
                        "basic:calendarUnitManagement:scheduleUnit:editschedulestatus",
                      url: null,
                      sortNo: "4",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                  ],
                },
              ],
            },
            {
              id: "5",
              parentId: "0",
              name: "系统信息",
              identification: null,
              url: "/bmgl",
              sortNo: "5",
              menuType: "1",
              permissionGroupId: null,
              checkFlag: true,
              platformId: "1651478710725455875",
              children: [
                {
                  id: "89",
                  parentId: "5",
                  name: "编码管理",
                  identification: null,
                  url: "bmgl",
                  sortNo: "1",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "90",
                      parentId: "89",
                      name: "修改",
                      identification: "basic:codeManage:code:edit",
                      url: null,
                      sortNo: "1",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                    {
                      id: "91",
                      parentId: "89",
                      name: "设置状态",
                      identification: "basic:codeManage:code:editcodestatus",
                      url: null,
                      sortNo: "2",
                      menuType: "4",
                      permissionGroupId: null,
                      checkFlag: true,
                      platformId: "1651478710725455875",
                      children: [],
                    },
                  ],
                },
                {
                  id: "92",
                  parentId: "5",
                  name: "操作日志",
                  identification: null,
                  url: "operateLog",
                  sortNo: "2",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [],
                },
                {
                  id: "93",
                  parentId: "5",
                  name: "信息导入",
                  identification: null,
                  url: "informationImport",
                  sortNo: "3",
                  menuType: "2",
                  permissionGroupId: null,
                  checkFlag: true,
                  platformId: "1651478710725455875",
                  children: [
                    {
                      id: "pagInfo-7",
                      parentId: "93",
                      name: "数据导入",
                      identification: null,
                      url: null,
                      sortNo: null,
                      menuType: "3",
                      permissionGroupId: null,
                      checkFlag: null,
                      platformId: null,
                      children: [
                        {
                          id: "94",
                          parentId: "pagInfo-7",
                          name: "模板下载",
                          identification:
                            "basic:Infoimport:import:downloadtemplate",
                          url: null,
                          sortNo: "1",
                          menuType: "4",
                          permissionGroupId: "7",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                        {
                          id: "95",
                          parentId: "pagInfo-7",
                          name: "数据导入",
                          identification:
                            "basic:Infoimport:import:importtemplate",
                          url: null,
                          sortNo: "2",
                          menuType: "4",
                          permissionGroupId: "7",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                      ],
                    },
                    {
                      id: "pagInfo-8",
                      parentId: "93",
                      name: "导入记录",
                      identification: null,
                      url: null,
                      sortNo: null,
                      menuType: "3",
                      permissionGroupId: null,
                      checkFlag: null,
                      platformId: null,
                      children: [
                        {
                          id: "96",
                          parentId: "pagInfo-8",
                          name: "错误数据下载",
                          identification:
                            "basic:Infoimport:import:downloaderrdata",
                          url: null,
                          sortNo: "3",
                          menuType: "4",
                          permissionGroupId: "8",
                          checkFlag: true,
                          platformId: "1651478710725455875",
                          children: [],
                        },
                      ],
                    },
                  ],
                },
              ],
            },
          ],
        },
      ],
    };
  },
  components: {
    // selectTree,
    HSKselecte,
  },
  props: {},
  watch: {},
  created() {},
  mounted() {},
  methods: {
     onCateSelect(a,b){
      console.log("onCateSelect",a,b)
    },
    clearKey(a){
      console.log(a)
    },
    //获取勾选数据
    getdetail(val) {
      this.defaultKey = [];
      this.defaultKey.push(val);
      // this.form.workGroupId = val.workGroupId;
    },
    changeTreeItem(res) {
      console.log(res);
    },
    getGroupSequence() {
      return this.treeData;
    },
  },
};
</script>
<style scoped>
.flex1 {
  flex: 1;
}
</style>

文章来源:https://blog.csdn.net/qq_42696432/article/details/135361109
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。