vue3中el-table实现表格合计行

el-table标签上加属性 show-summary :summary-method="getSummary"

复制代码
 <el-table :data="formDate.scoreList" style="width:100%;height: 96%;" stripe show-summary
      :summary-method="calculateSummary" :header-cell-style="{ textAlign: 'center', borderColor: ' #CCC', background: '#f5f7fa' }"
                        :cell-style="{ textAlign: 'center' }">
      <el-table-column type="index" label="序号" width="120"></el-table-column>
      <el-table-column type="puuid" label="uuid" v-if="false"></el-table-column>
</el-table>
js中添加函数(合计没有额外的附件参数添加)
复制代码
// 合计
const calculateSummary = ({ columns, data }) => {
    const sums = []
    columns.forEach((column, index) => {
        if (index === 0) {
            sums[index] = '合计总分'
            return
        }
        const values = data.map((item) => Number(item[column.property]))
        // index === 3判断那一列求合计,下标从0开始
        if (!values.every((value) => Number.isNaN(value)) && index === 3) {
            sums[index] =` ${values.reduce((prev, curr) => {
                const value = Number(curr)
                if (!Number.isNaN(value)) {
                    return prev + curr
                } else {
                    return prev
                }
            }, 0)}`
        }
    })
    return sums
}
js中添加函数(合计有额外的附件参数添加的情况)
复制代码
let activeList=ref('')

// 合计
const calculateSummary = ({ columns, data }) => {
    const sums = []
    columns.forEach((column, index) => {
        if (index === 0) {
            sums[index] = '合计总分'
            return
        }
        // 通过自定义参数判断除了表格中的数据外还额外加值
        let a = activeList.value == 'first' ? 21 : activeList.value == 'second' ? 12 : activeList.value == 'third' ? 18 : 3
         // 获取表格中的数据
        const values = data.map((item) => Number(item[column.property]))
        //index === 3判断那一列求合计,下标从0开始
        if (!values.every((value) => Number.isNaN(value)) && index === 3) {
            // 通过计算额外值a+表格中的合计值(模板字符串无法直接相加需要转换数据格式)
            sums[index] = a+Number(` ${values.reduce((prev, curr) => {
                const value = Number(curr)
                if (!Number.isNaN(value)) {
                    return prev + curr
                } else {
                    return prev
                }
            }, 0)}`)
        }
    })
    return sums
}
相关推荐
酉鬼女又兒20 分钟前
入门前端CSS 媒体查询全解析:从入门到精通,打造完美响应式布局(可用于备赛蓝桥杯Web应用开发)
前端·css·职场和发展·蓝桥杯·前端框架·html5·媒体
Dxy123931021629 分钟前
HTML常用标签详解
前端·html
毛骗导演31 分钟前
@tencent-weixin/openclaw-weixin 插件深度解析(一):认证与会话管理机制
前端·架构
spencer_tseng33 分钟前
Vue node_modules
javascript·vue.js
wefly201739 分钟前
告别本地环境!m3u8live.cn一键实现 M3U8 链接预览与调试
前端·后端·python·音视频·m3u8·前端开发工具
SuperEugene41 分钟前
前端 console 日志规范实战:高效调试 / 垃圾 log 清理与线上安全避坑|编码语法规范篇
开发语言·前端·javascript·vue.js·安全
发现一只大呆瓜1 小时前
Vue - @ 事件指南:原生 / 内置 / 自定义事件全解析
前端·vue.js·面试
庄小焱1 小时前
React——React基础语法(1)
前端·javascript·vue.js
pingan87871 小时前
试试 docx.js 一键生成 Word 文档,效果很不错
开发语言·前端·javascript·ecmascript·word
张一凡932 小时前
重新理解 React 状态管理:用类的方式思考业务
前端·react.js