溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

發(fā)布時(shí)間:2023-03-11 11:00:31 來源:億速云 閱讀:107 作者:iii 欄目:開發(fā)技術(shù)

這篇文章主要介紹“Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算”的相關(guān)知識(shí),小編通過實(shí)際案例向大家展示操作過程,操作方法簡(jiǎn)單快捷,實(shí)用性強(qiáng),希望這篇“Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算”文章能幫助大家解決問題。

前言

table中有一項(xiàng)內(nèi)容是花銷的金額。然后想在table的底部有一項(xiàng)內(nèi)容是該金額的總計(jì)。然后我就順著elemetui的table組件尋找相關(guān)的demo,還真發(fā)現(xiàn)了一個(gè)這樣的demo。

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

對(duì)于這個(gè)demo,官方是這么描述的:

將show-summary設(shè)置為true就會(huì)在表格尾部展示合計(jì)行。默認(rèn)情況下,對(duì)于合計(jì)行,第一列不進(jìn)行數(shù)據(jù)求合操作,而是顯示「合計(jì)」二字(可通過sum-text配置),其余列會(huì)將本列所有數(shù)值進(jìn)行求合操作,并顯示出來。當(dāng)然,你也可以定義自己的合計(jì)邏輯。使用summary-method并傳入一個(gè)方法,返回一個(gè)數(shù)組,這個(gè)數(shù)組中的各項(xiàng)就會(huì)顯示在合計(jì)行的各列中,具體可以參考本例中的第二個(gè)表格。

通過描述可以發(fā)現(xiàn)幾個(gè)要點(diǎn):

1.可以通過show-summary開啟在表格尾部展示合計(jì)行,默認(rèn)是false,改成true即可開啟,第一列不進(jìn)行數(shù)據(jù)求合操作。
2.尾部合計(jì)的文案默認(rèn)是合計(jì),可以通過sum-text自定義修改
3.可以通過summary-method編寫一個(gè)函數(shù),自定義合計(jì)的邏輯

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

官方的原生代碼如下:

<template>
  <el-table
    :data="tableData"
    border
    show-summary
    >
    <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"
      sortable
      label="數(shù)值 1">
    </el-table-column>
    <el-table-column
      prop="amount2"
      sortable
      label="數(shù)值 2">
    </el-table-column>
    <el-table-column
      prop="amount3"
      sortable
      label="數(shù)值 3">
    </el-table-column>
  </el-table>

  <el-table
    :data="tableData"
    border
    height="200"
    :summary-method="getSummaries"
    show-summary
    >
    <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="數(shù)值 1(元)">
    </el-table-column>
    <el-table-column
      prop="amount2"
      label="數(shù)值 2(元)">
    </el-table-column>
    <el-table-column
      prop="amount3"
      label="數(shù)值 3(元)">
    </el-table-column>
  </el-table>
</template>

<script>
  export default {
    data() {
      return {
        tableData: [{
          id: '12987122',
          name: '王小虎',
          amount1: '234',
          amount2: '3.2',
          amount3: 10
        }, {
          id: '12987123',
          name: '王小虎',
          amount1: '165',
          amount2: '4.43',
          amount3: 12
        }, {
          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
        }]
      };
    },
    methods: {
      getSummaries(param) {
        const { columns, data } = param;
        const sums = [];
        columns.forEach((column, index) => {
          if (index === 0) {
            sums[index] = '總價(jià)';
            return;
          }
          const values = data.map(item => Number(item[column.property]));
          if (!values.every(value => isNaN(value))) {
            sums[index] = values.reduce((prev, curr) => {
              const value = Number(curr);
              if (!isNaN(value)) {
                return prev + curr;
              } else {
                return prev;
              }
            }, 0);
            sums[index] += ' 元';
          } else {
            sums[index] = 'N/A';
          }
        });

        return sums;
      }
    }
  };
</script>

接下來就改造下代碼,根據(jù)自己的需求去修改對(duì)應(yīng)的邏輯。

show-summary合計(jì)項(xiàng)初始化

首先把相關(guān)的代碼加上,初始化就是這樣的一個(gè)效果

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

sum-tex修改文案

但是默認(rèn)的文案是合計(jì),有時(shí)候我們可能需要根據(jù)自己的場(chǎng)景進(jìn)行修改

這時(shí)候就可以使用sum-tex屬性進(jìn)行修改了,比如我這里修改:

sum-text="總共消費(fèi)

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

效果馬上就來

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

但是這時(shí)候還有一個(gè)問題,我只想要消費(fèi)金額這一列進(jìn)行匯總,但是現(xiàn)在的情況是把table全部的列都匯總了。甚至把我的字典值都匯總了。

這顯然不符合我的需求,這時(shí)候就可以使用自定義函數(shù)了。

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

summary-method自定義函數(shù)

和前面兩個(gè)屬性一樣,直接加在table中即可。由于它的值是一個(gè)函數(shù),所以寫法和前兩位略有不同。

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

我們也可以再這個(gè)函數(shù)里面通過 sums[index] 去定義總價(jià)的文案,如果sum-text和函數(shù)里面定義的 sums[index] 有沖突,會(huì)以函數(shù)中的 sums[index] 文案為主

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

這時(shí)候的效果是這樣的。

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

自定義總計(jì)列 單個(gè)列

如果我們只想要對(duì)某一列進(jìn)行總計(jì),那么可以借助column的property屬性:

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

可以發(fā)現(xiàn)其實(shí)就是全部的屬性名稱,那么我們就可以根據(jù)它判斷,實(shí)現(xiàn)自定義核算了

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

比如這里我想要核算amount這一列的值:

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

多個(gè)列

如果哪天又加了一個(gè)需求,需要再算一個(gè)列,這時(shí)候在判斷里面加上這個(gè)條件即可。使用|| 拼接該列

比如這里我又要合算remark這一列。就可以這么寫:

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算

相關(guān)代碼如下:

<el-table 
      :data="moneyTableData.slice((currentPage-1)*pagesize,currentPage*pagesize)"  
      highlight-current-row 
      border 
      stripe
      fit
      show-summary
      sum-text="總共消費(fèi)"
      :summary-method="getSummaries"
    >

// 對(duì)列進(jìn)行合算
    getSummaries(param) {
        const { columns, data } = param;
        const sums = [];
        columns.forEach((column, index) => {
          if (index === 0) {
            sums[index] = '總共消費(fèi)';
            return;
          }
          const values = data.map(item => Number(item[column.property]));
          // 只對(duì)amount這一列進(jìn)行總計(jì)核算。
         if (column.property === 'amount') {
            if (!values.every(value => isNaN(value))) {
                sums[index] = values.reduce((prev, curr) => {
                const value = Number(curr);
                if (!isNaN(value)) {
                    return prev + curr;
                }else {
                    return prev;
                }
              }, 0);
                sums[index] += ' 元';
              } else {
                sums[index] = '---'
            }
         }
      });
        return sums;
    },

關(guān)于“Vue怎么使用ElemenUI對(duì)table的指定列進(jìn)行合算”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí),可以關(guān)注億速云行業(yè)資訊頻道,小編每天都會(huì)為大家更新不同的知識(shí)點(diǎn)。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI