zoukankan      html  css  js  c++  java
  • vue+element-ui动态生成多级表头,并且将有相同字段下不同子元素合并为同一个

    element表头要多层生成,下一级表头数据源必须是当前表头的子一级,这样一层一层嵌套可以生成多层表头:

    要把数据处理成这种类型的数据

               var arr = [];
                for (var key in obj) {
                  var item = {};
                  item.children = new Object()
                  item.children[key] = obj[key]
                  item.id = res[0][key]
                  item.lable = res[1][key];
                  arr.push(item);
                }

    在vue的页面上对于循环的处理也是要多层循环:

      <el-table-column v-for="(item,key1) in tablehead"  :key="key1" :label="item.lable" v-if="key1!=0">
             <el-table-column v-for="(value,key) in item.children" :prop="key" :key="key" :label-class-name="key" :label="value" :id="key">
              <!-- 如果要生成多层循环表头,在这里面一直嵌套处理一下就行了 -->
          </el-table-column>
        </el-table-column>

     对于用别人的ui框架,最好就是改下数据源,适应框架的数据源的结构:

    之前数据结构是这种

    现在要把每项相同lable的数据的children放在一个下面;

    :

    将相同字段合并为一个

                var temp = [],
                    ob = {}
                for(var i in arr){
                  let item = arr[i]
                  if(!ob[item.lable]){
                    temp.push({
                      lable:item.lable,
                      id:item.id,
                      children:item.children
                    });
                    ob[item.lable] = item.lable
                  }else{
                    for(var j in temp){
                      if(temp[j].lable == item.lable){
                        for(var o in item.children){
                          // 通过对象循环给把每个children的赋值给一个
                          temp[j].children[o]= item.children[o]
                        }
                      }
                    }
                  }
                }
  • 相关阅读:
    延迟满足是一件在优秀的道路上你必须习惯的事情
    你活成了你的职位嘛?
    《自律力——创建持久的行为习惯,成为你想成为的人》读书笔记
    期末大作业
    第7次实践作业
    第6次实践作业
    第5次实践作业
    第4次实践作业
    第3次实践作业
    第2次实践作业
  • 原文地址:https://www.cnblogs.com/Tohold/p/9604128.html
Copyright © 2011-2022 走看看