JS 无限分类树

一、 常用的JS无限分类。

常用无限分类,一般存在两种情况,一种是存储在children 子节点当中。一种是利用level层级排序的方式进行手动分类。前者在组件与其他插件当中使用较多,后者在下拉框组件当中使用的挺多的。

自己呢,从事的是后端语言开发,往常在后端使用PHP引用的特性,第一种方式和第二种都是很容易就可以实现。最近在是用vue进行前端开发。在使用树组件的时候就遇到了这个问题。记录下自己做数据处理的想法与步骤。

  • 储存children当中

思路:使用while 循环进行处理。首先进行两两之间的添加children之后将最下层的叶子删除,然后继续循环处理,直至只剩下顶层节点。

 treeData(treeData) {
        let j = 0;
          let baseSize =new Set();
          while (true) {
              let size = treeData.length;
              let a = false;  //元素删除控制位
              if (size <= 1 || !treeData[j] || size == baseSize.size) {
                  break;
              }
              if (treeData[j].pid == 0) {
                  baseSize.add(treeData[j].id);
              }
              for (let i = 0; i < size; i++) {
                  treeData[i].title = treeData[i].name;
                  if (treeData[i].pid == treeData[j].id) {
                      a = true;
                  }
                  //解决数据位置顺序错乱导致误删
                  if (treeData[i].id == treeData[j].pid) {
                      if (!treeData[i].hasOwnProperty('children')) {
                          treeData[i].children = [];
                      }
                      treeData[i].children[treeData[j].id] = treeData[j];
                  }
              }
              if (!a && treeData[j].pid != 0) {
                  treeData.splice(j, 1);
              }
              j++;
              if (j >= size - 1) {
                  j = 0;
              }    
          }
          return treeData;
      }
  • 第二种通过level来进行分类
  treeMenu(tree, pid, level) {
            for (var i = 0; i < tree.length; i++) {
                if (tree[i].pid == pid) {
                    let item = tree[i];
                    tree[i].level = level;
                    this.selectData.push(tree[i]);
                    this.treeMenu(tree, item.id, level + 1);
                }
            }
            return this.selectData;
        }

好了,虽然说代码不多,但碍于对JS的理解不太多,导致花的时间较多。需要说明一个问题就是,在vue里调用这两个方法时要注意顺序问题,不知道vue内容对数组处理是不是基于引用进行的。如果这两个方法最原始的数组对象是同一个的话,先调用第一个方法,再调用第二个话,可能达不到自己想要的结果。

最后在vue里面一定要注意,JS变量深拷贝和浅拷贝的问题,对于对象或者数组类型的话,最好进行深拷贝。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 背景 一年多以前我在知乎上答了有关LeetCode的问题, 分享了一些自己做题目的经验。 张土汪:刷leetcod...
    土汪阅读 14,354评论 0 33
  • 1. Java基础部分 基础部分的顺序:基本语法,类相关的语法,内部类的语法,继承相关的语法,异常的语法,线程的语...
    子非鱼_t_阅读 32,187评论 18 399
  • The winer say“当我骑自行车时,别人说路途太远,根本不可能到达目的地,我没理,半道上我换成小轿车;当我...
    沐名今生阅读 1,917评论 0 2
  • 大家知道什么是外瘦内胖吗? 外瘦内胖的情况中国人通常会多一点,就是表面看起来不胖,但是身体脂肪量比正常的体质要高很...
    f69b661ee123阅读 9,258评论 2 53
  • 我要讲一个故事。 昨天夜里做梦,梦里走到一个大川大野的地方,深山里有一颗巨大无比的奇树,它与众不同,其它树是根根直...
    赖先森00阅读 2,713评论 0 0