iview table合并行/列

<template>
    <Table :columns="columns" height="200" :data="newData" border :span-method="handleSpan"></Table>
</template>
<script>
    export default {
        data () {
            return {
                columns: [
                    {
                        title: 'Age',
                        key: 'age'
                    },
                    {
                        title: 'Date',
                        key: 'date'
                    },
                    {
                        title: 'Name',
                        key: 'name'
                    },
                    {
                        title: 'Address',
                        key: 'address'
                    }
                ],
                data: [
                    {
                        name: 'John Brown',
                        age: 18,
                        address: 'New York No. 1 Lake Park',
                        date: '2016-10-03'
                    },
                    {
                        name: 'Jim Green',
                        age: 18,
                        address: 'London No. 1 Lake Park',
                        date: '2016-10-01'
                    },
                    {
                        name: 'Jim Green',
                        age: 24,
                        address: 'London No. 1 Lake Park',
                        date: '2016-10-01'
                    },
                    {
                        name: 'Joe Black',
                        age: 30,
                        address: 'Sydney No. 1 Lake Park',
                        date: '2016-10-02'
                    },
                    {
                        name: 'Jon Snow',
                        age: 30,
                        address: 'Ottawa No. 2 Lake Park',
                        date: '2016-10-04'
                    },
                    {
                        name: 'Jon Snow',
                        age: 30,
                        address: 'Ottawa No. 2 Lake Park',
                        date: '2016-10-04'
                    }
                ],
                newData: []
            }
        },
        created() {
          let that = this;
          that.newData = that.integratedData(that.data);
        },
        methods: {
            // 被整理的数组中相同age的元素需放在一块,否则还要再整理数据(暂未处理)
            integratedData(data) {
                let that = this;
                // 获取所有的不同年龄值
                let arrId = [];
                data.forEach(i => {
                    !arrId.includes(i.age) ? arrId.push(i.age) : arrId;
                });
                // 提前为每个年龄值设置跨行数为0
                let arrObj = [];
                arrId.forEach(j => {
                    arrObj.push({
                        id: j,
                        num: 0
                    })
                })
                // 计算每个年龄的可跨行数
                data.forEach(k => {
                    arrObj.forEach(l => {
                        k.age === l.id ? l.num ++ : l.num;
                    })
                })
                data.forEach(m => {
                    arrObj.forEach((n,index) => {
                        if(m.age === n.id){
                            if(arrId.includes(m.age)){
                                m.mergeCol = n.num;
                                arrId.splice(arrId.indexOf(m.age),1);
                            }else{
                                m.mergeCol = 0;
                            }
                        }
                    })
                })
                return data;
            },
            // 只针对相同age字段合并列,age位于第一列,columnIndex为0
            handleSpan ({ row, column, rowIndex, columnIndex }) {
                if (columnIndex === 0) {
                    return {
                        rowspan: row.mergeCol === 0 ? 0:row.mergeCol,
                        colspan: row.mergeCol === 0 ? 0:1
                    };
                }
            }
        }
    }
</script>

效果如下图
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值