element-uiテーブル:span-method(行を動的にマージ)

element-uiの公式ウェブサイトでの行のマージの例は、行番号に基づいてマージすることです。これは、通常、テーブル内のデータが動的に生成されるため、いくつかの変更が必要なため、明らかに日常の開発ニーズを満たしていません。まず、公式Webサイトインスタンスの各パラメーターの意味を解釈しましょう。

objectSpanMethod({
    
     row, column, rowIndex, columnIndex }) {
    
    
        if (columnIndex === 0) {
    
        //用于设置要合并的列
          if (rowIndex % 2 === 0) {
    
       //用于设置合并开始的行号
            return {
    
    
              rowspan: 2,     //合并的行数
              colspan: 1          //合并的列数,设为0则直接不显示
            };
          } else {
    
    
            return {
    
    
              rowspan: 0,
              colspan: 0
            };
          }
        }
      }

画像の例:
IDデータに基づいて列を動的にマージします。
ここに画像の説明を挿入

機能コード:
データソースは判定条件に従ってソートする必要があります。ここでは例としてidを取り上げます。

var Main = {
    
    
    data() {
    
    
      return {
    
    
        tableData: [
          {
    
    
          id: '12987122',
          name: '王小虎',
          amount1: '234',
          amount2: '3.2',
          amount3: 10
        },
          {
    
    
          id: '12987122',
          name: '王小虎',
          amount1: '123',
          amount2: '12',
          amount3: 10
        }, {
    
    
          id: '12987123',
          name: '王小虎',
          amount1: '165',
          amount2: '4.43',
          amount3: 12
        }, {
    
    
          id: '12987124',
          name: '王小虎',
          amount1: '324',
          amount2: '1.9',
          amount3: 9
        }, 
          {
    
    
          id: '12987124',
          name: '王小虎',
          amount1: '324',
          amount2: '1.9',
          amount3: 9
        },
          {
    
    
          id: '12987124',
          name: '王小虎',
          amount1: '324',
          amount2: '1.9',
          amount3: 9
        },{
    
    
          id: '12987125',
          name: '王小虎',
          amount1: '621',
          amount2: '2.2',
          amount3: 17
        }, {
    
    
          id: '12987126',
          name: '王小虎',
          amount1: '539',
          amount2: '4.1',
          amount3: 15
        }
        ],
        merge:[],  //存放需要合并的行
        pos:''   //需要合并行下标
      };
    },
  created() {
    
    
    this.getSpanArr(this.tableData)
  },
    methods: {
    
    
      getSpanArr(data) {
    
     
          for (var i = 0; i < data.length; i++) {
    
    
                if (i === 0) {
    
    
                      this.merge.push(1);
                      this.pos = 0
                } else {
    
    
               // 判断当前元素与上一个元素是否相同
            //根据相同id进行合并,根据需要可进行修改
            if (data[i].id === data[i - 1].id) {
    
    
                        this.merge[this.pos] += 1;
                        this.merge.push(0);
                      } else {
    
    
                        this.merge.push(1);
                        this.pos = i;
                      }
                }
            }
        },
        SpanCellMerge({
    
     row, column, rowIndex, columnIndex }) {
    
    
              if (columnIndex === 0) {
    
    
                    const _row = this.merge[rowIndex];
                    const _col = _row > 0 ? 1 : 0;
                    return {
    
    
                          rowspan: _row,
                          colspan: _col
                    }
              }
        },
      
      }
 
  };
var Ctor = Vue.extend(Main)
new Ctor().$mount('#app')

dataはバックグラウンドから取得するデータであり、通常は配列です。mergeは空の配列であり、各行のマージされたレコードの数を格納するために使用されます
。posはマージのインデックスです。上記のコードは次のことを意味します:それが最初のレコード(インデックスが0)の場合、配列に1を追加し、インデックスの位置を設定します。
最初のレコードでない場合は、前のレコードと等しいかどうかを判断します。、次に要素0を追加してマージし、前の要素+1はマージされた行の数+1を意味し、次に往復してすべての行のマージされた数を取得します。0は行が表示されないことを意味します。

ページコード:

<template>
  <div>
  
    <el-table
      :data="tableData"
      :span-method="SpanCellMerge"
      border
      style="width: 100%; margin-top: 20px">
      <el-table-column
        prop="id"
        label="ID"
        width="180">
      </el-table-column>
      <el-table-column
        prop="name"
        label="姓名">
      </el-table-column>
      <el-table-column
        prop="amount1"
        label="数值 1(元)">
      </el-table-column>
      <el-table-column
        prop="amount2"
        label="数值 2(元)">
      </el-table-column>
      <el-table-column
        prop="amount3"
        label="数值 3(元)">
      </el-table-column>
    </el-table>
  </div>
</template>

おすすめ

転載: blog.csdn.net/qq_25288617/article/details/109390095