如何在元素UI表中显示嵌套的单元格?

时间:2019-05-20 07:30:00

标签: vue.js element-ui

我正在使用Element UI。我有嵌套的数据,需要在表中显示。我不明白如何显示嵌套数据的问题。

这是我的代码:

 <el-table :data="tableData" stripe border>
  <el-table-column width="170" prop="id"></el-table-column>
  <el-table-column width="170">
    <template slot-scope="scope">
    <!-- -->
    </template>
  </el-table-column>

 </el-table>

数据部分:

  tableData: [
   {
   "id":1,
   "nested": [{"name": "mike"}, {"name": "piter"}]
   },
   {
   "id":2,
   "nested": [{"name": "maria"}, {"name": "anna"}]
   },      
  ]

  };

https://jsfiddle.net/3nhb79qc/

我想显示为:enter image description here

1 个答案:

答案 0 :(得分:0)

一种解决方案是使用span-method in Element UI Table

首先,使用计算方法来整理数据结构:

computed: {
  expandData() {
    return this.tableData.reduce((a, c) => {
      const arr = c.nested.map(item => ({
        id: c.id,
        name: item.name
      }))
      a = a.concat(arr)
      return a

    }, [])
  }
},

那么您的数据将变为:

[
    {
        "id": 1,
        "name": "mike"
    },
    {
        "id": 1,
        "name": "piter"
    },
    {
        "id": 2,
        "name": "maria"
    },
    {
        "id": 2,
        "name": "anna"
    }
]

在此之后定义objectSpanMethod并在el-table中使用

  objectSpanMethod({ row, column, rowIndex, columnIndex }) {
    if (columnIndex === 0) {
      if (rowIndex % 2 === 0) {
        return {
          rowspan: 2,
          colspan: 1
        };
      } else {
        return {
          rowspan: 0,
          colspan: 0
        };
      }
    }
  }

Demo on jsfiddle