欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ElementUI對table的指定列進(jìn)行合算

 更新時間:2023年03月16日 15:46:47   作者:小花皮豬  
本文主要介紹了ElementUI對table的指定列進(jìn)行合算,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

最近有一個想法,就是記錄自己花銷的時候,table中有一項內(nèi)容是花銷的金額。然后想在table的底部有一項內(nèi)容是該金額的總計。

然后我就順著elementui的table組件尋找相關(guān)的demo,還真發(fā)現(xiàn)了一個這樣的demo。

對于這個demo,官方是這么描述的:

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

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

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

官方的原生代碼如下:

<template>
  <el-table
    :data="tableData"
    border
    show-summary
    style="width: 100%">
    <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
    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="數(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] = '總價';
            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ù)自己的需求去修改對應(yīng)的邏輯。

show-summary合計項初始化

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

sum-tex修改文案

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

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

sum-text="總共消費

效果馬上就來

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

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

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

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

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

這時候的效果是這樣的。

自定義總計列

單個列

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

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

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

多個列

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

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

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

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

// 對列進(jìn)行合算
    getSummaries(param) {
        const { columns, data } = param;
        const sums = [];
        columns.forEach((column, index) => {
          if (index === 0) {
            sums[index] = '總共消費';
            return;
          }
          const values = data.map(item => Number(item[column.property]));
          // 只對amount這一列進(jìn)行總計核算。
         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;
    },

總結(jié)

ElemenUI對這個demo封裝的特別好,我們直接拿來用修改下自己的邏輯即可。

到此這篇關(guān)于ElementUI對table的指定列進(jìn)行合算的文章就介紹到這了,更多相關(guān)Element table指定列合算內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue-cil之a(chǎn)xios的二次封裝與proxy反向代理使用說明

    vue-cil之a(chǎn)xios的二次封裝與proxy反向代理使用說明

    這篇文章主要介紹了vue-cil之a(chǎn)xios的二次封裝與proxy反向代理使用說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue實現(xiàn)圖片預(yù)覽功能的詳細(xì)指南

    Vue實現(xiàn)圖片預(yù)覽功能的詳細(xì)指南

    在現(xiàn)代 web 應(yīng)用程序中,圖片預(yù)覽功能提升了用戶體驗,使用戶可以在上傳圖片之前查看圖片內(nèi)容,本文將詳細(xì)介紹如何在 Vue.js 應(yīng)用中實現(xiàn)圖片預(yù)覽功能,包括基本實現(xiàn)、進(jìn)階功能、與 Element UI 的集成、常見優(yōu)化技巧以及與其他庫的結(jié)合使用,需要的朋友可以參考下
    2024-09-09
  • 淺談vuepress 踩坑記

    淺談vuepress 踩坑記

    本篇文章主要介紹了淺談vuepress 踩坑記,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • vue如何循環(huán)給對象賦值

    vue如何循環(huán)給對象賦值

    這篇文章主要介紹了vue如何循環(huán)給對象賦值,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • 在vue中使用css modules替代scroped的方法

    在vue中使用css modules替代scroped的方法

    本篇文章主要介紹了在vue中使用css modules替代scroped的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-03-03
  • vue?router?動態(tài)路由清除方式

    vue?router?動態(tài)路由清除方式

    這篇文章主要介紹了vue?router?動態(tài)路由清除方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • vue v-on傳遞參數(shù)和事件修飾符的使用

    vue v-on傳遞參數(shù)和事件修飾符的使用

    本文主要介紹了vue v-on傳遞參數(shù)和事件修飾符的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-01-01
  • vue實現(xiàn)多級側(cè)邊欄的封裝

    vue實現(xiàn)多級側(cè)邊欄的封裝

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)多級側(cè)邊欄的封裝,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • Vue中插槽Slot基本使用與具名插槽詳解

    Vue中插槽Slot基本使用與具名插槽詳解

    有時候我們希望在指定的位置輸出我們的子元素,這時候具名插槽就排上了用場,這篇文章主要給大家介紹了關(guān)于Vue中插槽Slot基本使用與具名插槽的相關(guān)資料,需要的朋友可以參考下
    2022-10-10
  • Vue中this.$router和this.$route的區(qū)別及push()方法

    Vue中this.$router和this.$route的區(qū)別及push()方法

    這篇文章主要給大家介紹了關(guān)于Vue中this.$router和this.$route的區(qū)別及push()方法的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05

最新評論