vue 数组转组织树

 // 树节点中查询遍历组织
    getNode(data, key, val) {
      let treeNode = "";
      data.some(item => {
        let flag = false;
        console.log("item[" + key + "]", item[key], "val", val);
        if (item[key] === val) {
          treeNode = item;
          flag = true;
        } else if (item.children && item.children.length) {
          treeNode = this.getNode(item.children, key, val);
          if (treeNode) flag = true;
        }
        return flag;
      });
      return treeNode;
    },
    changeCurrentNode(id) {
      var id = this.$isEmpty(id) ? "" : id;
      this.$nextTick(() => {
        this.$refs.tree.setCurrentKey(this.$isEmpty(id) ? null : id);
      });
      this.currentNodeKey = id;
      this.$nextTick(() => {
        const node = this.$refs.tree.getNode(this.currentNodeKey);
        console.log("node--->", node);
        this.handleNodeClick(node.data);
        this.scrollToTreeCurrent(node);
      });
    },
    // 定位到tree选择位置
    scrollToTreeCurrent(parentNode) {
      if (!parentNode) return false;
      let level = -1;
      let dom = document.querySelector(".brand-tree"); // 获取 tree外层的dom
      let nodeCount = 0; // tree中展开节点总数
      let nodeIndex = 0; // tree中选中节点

      // 获取tree节点高度
      let nodeHeight = 30;

      // 通过选中节点 获取顶层父节点 并展开
      while (level != 0) {
        this.$refs.tree.store.nodesMap[
          parentNode.data[this.nodeKey]
        ].expanded = true;
        parentNode = parentNode.parent;
        level = parentNode.level;
      }

      this.$nextTick(() => {
        const getNodeCount = function(val) {
          val.childNodes.forEach(e => {
            nodeCount++;
            if (e.isCurrent) {
              nodeIndex = nodeCount;
            }
            if (e.expanded) {
              getNodeCount(e);
            }
          });
        };
        getNodeCount(parentNode); // 获取展开节点总数和高亮节点位置

        // 计算 选中节点位置 并通过scrollTo方法定位
        let height = Number(
          window.getComputedStyle(dom).height.replace("px", "")
        );
        // 计算位置大约在tree中间
        let scroll = Math.max(nodeIndex * nodeHeight - 0.4 * height, 0);
        console.log("scroll--->", window.getComputedStyle(dom).height);
        setTimeout(() => {
          dom.scrollTo(0, scroll);
        }, 300);
      });
    },

//数组转为组织树
    arrToTree(_data) {
      let data = this.$deepClone(_data);
      let result = [];
      if (!Array.isArray(data)) {
        return result;
      }
      data.forEach(item => {
        delete item.children;
      });
      let map = {};
      data.forEach((item, index) => {
        item.index = index;
        map[item.id] = item;
      });
      data.forEach(item => {
        let parent = map[item.pId];

        if (parent) {
          (parent.children || (parent.children = null)).push(item);
        } else {
          result.push(item);
        }
      });
      return this.arrayTreeAddLevel(result);
    },
    // 给组织树添加level标识
    arrayTreeAddLevel(array, levelName = "level", childrenName = "children") {
      if (!Array.isArray(array)) return [];
      const recursive = (
        array,
        level = -1,
        name = "",
        nameSecond = this.nameSecond
      ) => {
        level++;
        return array.map(v => {
          v[levelName] = level;
          v[nameSecond] = name == "" ? v.name : name + "-" + v.name;
          const child = v[childrenName];
          if (child && child.length)
            recursive(child, level, v[nameSecond], nameSecond);
          return v;
        });
      };
      return recursive(array);
    },

  

posted @ 2022-12-06 10:51  Charlie098765  阅读(66)  评论(0编辑  收藏  举报