el-table合计行前置在首行,自定义合计行方法

背景

el-table原生合计行是在标签内增加show-summary属性,在表尾实现设计合计,且只对表格当前页面显示的列数据进行合计。element-UI效果如下图所示。

现要求在首行显示合计行,并自定义合计逻辑实现如下效果。

图示表格中,成本、收入、利润可以由列累加得;而利润率不能简单的直接累加,否则会出现利润率越来越高的情况,不符合生活常识和实际情况,因此该列的合计逻辑依然是【利润率 = 利润/收入】

前端

show-summary显示合计,:summary-method声明使用自定义合计方法。

html 复制代码
<el-table v-loading="loading" :data="costList" border
                          :header-cell-style="{backgroundColor: '#DFEBF8'}"
                          show-summary
                          :summary-method = "getSummaryMethod"">
                          <el-table-column....../>
                          <el-table-column....../>
                          <el-table-column....../>
                          <el-table-column....../>
                          <el-table-column....../>

</el-table>                          
  1. 合计行位置放到首行
javascript 复制代码
methods:{    
    /** 合计行设置 */
    showSummariesPosition () {
      // 合计行显示在表头
      let table = document.querySelector('.el-table')
      let footer = document.querySelector('.el-table__footer-wrapper')
      let body = document.querySelector('.el-table__body-wrapper')
      table.removeChild(footer)
      table.insertBefore(footer, body)
    },
 }
  1. 定义合计逻辑方法
javascript 复制代码
  data() {
    return {
    costList:[],	//接收后端数据
    }
  },
  created() {
    this.getSummaryMethod();
  },
  methods: {
	/** 自定义合计逻辑 */
    getSummaryMethod(params) {
      const { columns, data } = params;
      const sums = [];  //累加和
      const totalValue = [];  //存储列表,封装合计行要显示的数据
      columns.forEach((column, index) => {		//参数(列,列下标)
        sums [index] =0;	//累加和,初始化为0
        var i;
        if (index === 0) {	//第一列显示"合计"字样
          totalValue[index] = "合计";
          return;
        }
        if (index === 1) {  //第二列----总成本
          for (i = 0; i < this.costList.length; i++){	//循环累加
            sums[index] = this.costList[i].totalCost+sums[index];	
          };
          totalValue[index] = (sums[index]/10000).toFixed(2) + '万元';//格式化,保留两位小数
          //把累加和写入合计行列表
          return ;
        }
       if (index === 2) {   //第三列----总产值
         for (i = 0; i < this.costList.length; i++) {
           sums[index] = this.costList[i].totalOutput+sums[index];
         }
         totalValue[index] = (sums[index]/10000).toFixed(2) + '万元';
          return ;
        }
        if (index === 3) {    //第四列----利润
          sums[3] = sums[2]-sums[1];
          totalValue[index] = (sums[3]/10000).toFixed(2) + '万元';
          return ;
        }
        if (index === 4) {    //第五列----利润率 = 利润/收入
          totalValue[index] = (sums[3]/sums[2]*100).toFixed(2) + '%';
          return ;
        }
      });
      return totalValue;	//返回合计行列表
    },
}
相关推荐
子兮曰3 小时前
async/await高级模式:async迭代器、错误边界与并发控制
前端·javascript·github
恋猫de小郭3 小时前
2026 Flutter VS React Native ,同时在 AI 时代 VS Native 开发,你没见过的版本
android·前端·flutter
GIS之路5 小时前
ArcGIS Pro 中的 Notebooks 入门
前端
IT_陈寒7 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
lemon_yyds7 小时前
《vue 2 升级vue3 父组件 子组件 传值: value 和 v-model
vue.js
Kagol8 小时前
TinyVue 支持 Skills 啦!现在你可以让 AI 使用 TinyVue 组件搭建项目
前端·agent·ai编程
柳杉8 小时前
从零打造 AI 全球趋势监测大屏
前端·javascript·aigc
simple_lau8 小时前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生8 小时前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js
天蓝色的鱼鱼8 小时前
模块化与组件化:90%的前端开发者都没搞懂的本质区别
前端·架构·代码规范