vue3 el-table 列数据合计

在 Vue 3 中使用 Element Plus 的 <el-table> 组件时,如果你想要对列数据进行合计(即计算某一列的总和),你可以通过几种方式来实现。以下是几种常见的方法:

方法1:使用计算属性

你可以在 Vue 组件的 computed 属性中计算合计值。

复制代码
<template>
  <el-table :data="tableData" border style="width: 100%">
    <el-table-column prop="date" label="日期" width="180"></el-table-column>
    <el-table-column prop="name" label="姓名" width="180"></el-table-column>
    <el-table-column prop="amount" label="金额"></el-table-column>
  </el-table>
  <div>合计: {{ totalAmount }}</div>
</template>
 
<script setup>
import { ref, computed } from 'vue';
 
const tableData = ref([
  { date: '2023-04-01', name: '张三', amount: 100 },
  { date: '2023-04-02', name: '李四', amount: 200 },
  // 更多数据...
]);
 
const totalAmount = computed(() => {
  return tableData.value.reduce((sum, item) => {
    return sum + item.amount;
  }, 0);
});
</script>

方法2:使用方法(Method)

你也可以在 Vue 组件的方法中计算合计值,然后在模板中调用这个方法。

复制代码
<template>
  <el-table :data="tableData" border style="width: 100%">
    <el-table-column prop="date" label="日期" width="180"></el-table-column>
    <el-table-column prop="name" label="姓名" width="180"></el-table-column>
    <el-table-column prop="amount" label="金额"></el-table-column>
  </el-table>
  <div>合计: {{ calculateTotalAmount() }}</div>
</template>
 
<script setup>
import { ref } from 'vue';
 
const tableData = ref([
  { date: '2023-04-01', name: '张三', amount: 100 },
  { date: '2023-04-02', name: '李四', amount: 200 },
  // 更多数据...
]);
 
function calculateTotalAmount() {
  return tableData.value.reduce((sum, item) => {
    return sum + item.amount;
  }, 0);
}
</script>

方法3:使用 Element Plus 的 <el-table-column>summary-method 属性(适用于 Element Plus 2.x)

如果你使用的是 Element Plus 的旧版本,可以利用 <el-table>summary-method 属性来直接在表格底部显示合计。但请注意,Element Plus 在 Vue 3 中通常指的是最新版本,该版本可能不支持此属性或其用法有所变化。对于 Vue 3 和 Element Plus 的最新版本,推荐使用计算属性或方法。如果你在使用旧版本的 Element Plus,可以这样设置:

复制代码
<template>
  <el-table :data="tableData" border style="width: 100%" show-summary :summary-method="sumMethod">
    <el-table-column prop="date" label="日期" width="180"></el-table-column>
    <el-table-column prop="name" label="姓名" width="180"></el-table-column>
    <el-table-column prop="amount" label="金额"></el-table-column>
  </el-table>
</template>

<script setup>
import { ref } from 'vue';

// 示例数据初始化
const tableData = ref([
  { date: '2023-01-01', name: '张三', amount: 100 },
  { date: '2023-01-02', name: '李四', amount: 200 },
  { date: '2023-01-03', name: '王五', amount: 300 }
]);

// 自定义合计方法
const sumMethod = ({ columns, data }) => {
  const sums = [];
  
  columns.forEach((column, index) => {
    if (index === 0) {
      // 第一列显示"合计"
      sums[index] = '合计';
      return;
    }
    
    if (column.property === 'amount') {
      // 金额列计算总和
      const values = data.map(item => Number(item[column.property]));
      sums[index] = values.reduce((acc, curr) => acc + curr, 0);
      
      // 添加单位/格式化显示
      sums[index] += ' 元';
    } else {
      // 非数值列留空
      sums[index] = '';
    }
  });

  return sums;
};
</script>

对于 Vue 3 和 Element Plus 的最新版本,推荐使用计算属性或方法,因为 summary-method 在新版中可能已经被弃用或用法有所改变。确保查阅最新的官方文档以获取最准确的信息和示例

相关推荐
南风木兮丶几秒前
Vue 项目安装 @antfu/eslint-config 保姆级教程
前端·javascript·vue.js
万少13 分钟前
记 HarmonyOS 开发中的一个小事件 怒提华为工单
前端·harmonyos
未来之窗软件服务15 分钟前
万象EXCEL开发(六)excel单元格运算逻辑 ——东方仙盟金丹期
前端·excel·仙盟创梦ide·东方仙盟·万象excel
mldong17 分钟前
保姆级教程!手把手教你搭建FastAPI + Vue3前后端分离项目
vue.js·python·全栈
Mintopia22 分钟前
🚀 Cesium-Kit:10 秒为你的 Cesium 项目添加动态光效标记
前端·javascript·cesium
Mintopia24 分钟前
🌩️ 云边协同架构下的 WebAI 动态资源调度技术
前端·javascript·aigc
Olrookie25 分钟前
若依前后端分离版学习笔记(十六)——scoped、路由跳转
前端·笔记
qaqxiaolei26 分钟前
高效办公利器:前端实现表格导出excel格式 + 自定义水印的完整方案
前端·javascript
叫我詹躲躲28 分钟前
为什么Bun.js能在3秒内启动一个完整的Web应用?
前端·javascript·bun
Olrookie29 分钟前
若依前后端分离版学习笔记(十七)——ruoyi开发规范&流程,请求流程,依赖引入,组件注册&通信
前端·笔记