JS 无限分类树

作者: diamonds_A | 来源:发表于2017-07-14 14:43 被阅读0次
一、 常用的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变量深拷贝和浅拷贝的问题,对于对象或者数组类型的话,最好进行深拷贝。

相关文章

  • JS 无限分类树

    一、 常用的JS无限分类。 常用无限分类,一般存在两种情况,一种是存储在children 子节点当中。一种是利用l...

  • php无限分类树

    gihub地址 安装 composer require dendrogram/dendrogram:v1.0 ...

  • 预排序遍历树

    什么是左右值无限级分类左右值无限级分类,也称为预排序树无限级分类,是一种有序的树状结构,位于这些树状结构中的每一个...

  • 2018-11-29

    简单的无限分类树 public function tree2($arr,$pid) { $html = '...

  • JS 组装无限级树

  • 预排序树实现无限极分类

    一.概念 左右值无限级分类,也称为预排序树无限级分类 是一种有序的树状结构 于这些树状结构中的每一个节点都有一个 ...

  • 预排序遍历树-无限级分类

    表结构 新增:通过我们刚才新增数据得到这个结构的操作,我们发现新增分两种情况。第一种如下图所示:1:变更所有受影响...

  • php递归实现无限级分类树

    http://www.php.cn/php-weizijiaocheng-353267.html

  • 无限分类

    这是一个二级分类 怎么遍历出这个二级分类 利用递归 public static function getLei($...

  • php无限极分类

    递归--无限极分类 递归--子孙树转二维数组 可以配合Nestable使用 递归--获取树所有叶子节点 结果1 结...

网友评论

    本文标题:JS 无限分类树

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