Vue中怎么样实现table指定列求和,方法是什么
Admin 2022-07-13 群英技术资讯 912 次浏览
注意点:
1. <el-table> 中 加:summary-method="getSummaries"
2. <el-table-column> 中要加 prop
// 房间号的合计去掉 getSummaries (param) { const { columns, data } = param const sums = [] columns.forEach((column, index) => { if (index === 0) { sums[index] = '总计' } else if (index === 5 || index === 6) { 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) } else { sums[index] = 'N/A' } } else { sums[index] = '--' } }) return sums }
效果图
补充知识:vue+elementUI的表格最后一行合计自定义显示
1.在看了elementUI的文档后重要的俩个属性是 show-summary :summary-method="getSummaries" getSummaries这个是自定义方法函数的方法。
HTML的代码:
show-summary :summary-method="getSummaries的属性要加上,还有一个很重要的一点就是要 必须要在el-table-column中必须是prop来传值"
<el-table :key='tableKey' :data="listData" show-summary :summary-method="getSummaries" v-loading="listLoading" border fit highlight-current-row style="width:100%;margin-top:8px" :header-cell-style="{background:'oldlace'}">> <el-table-column prop="equipmentType" align="center" label="设备类型" min-width="50"> </el-table-column> <el-table-column prop="equipmentName" align="center" label="设备名称" min-width="50"> </el-table-column> <el-table-column prop="equipmentCode" align="center" label="设备编号" min-width="50"> </el-table-column> <el-table-column prop="openRate" align="center" label="开机率" min-width="50"> </el-table-column> <el-table-column prop="planWorkTime" align="center" label="计划工作时间" min-width="50"> </el-table-column> <el-table-column prop="closeTime" align="center" label="关机时间(h)" min-width="50"> </el-table-column> <el-table-column prop="machiningTime" align="center" label="加工时间(h)" min-width="50"> </el-table-column> <el-table-column prop="stopTime" align="center" label="停工时间(h)" min-width="50"> </el-table-column> <el-table-column prop="debugTime" align="center" label="调试时间(h)" min-width="50"> </el-table-column> <el-table-column align="center" label="查看" min-width="210"> <template slot-scope="scope"> <el-button title="时序图" type="primary" size="mini" @click="profile(scope.row)" v-show="SXTbatshow">时序图</el-button> <el-button title="状态时长统计图" type="danger" size="mini" @click="cartogram(scope.row)">状态时长统计图</el-button> <el-button title="状态占比图" type="success" size="mini" @click="diagram(scope.row)">状态占比图</el-button> </template> </el-table-column> </el-table>
在script要写的代码:
// 表格总计的时间 getSummaries(param) { const { columns, data } = param; /* console.log(1234) console.log(param) */ const sums = []; columns.forEach((column, index) => { if (index === 0) { sums[index] = '总计'; return; } //this.closeList等等是后台返回的总的数据,然后取值到这里 switch(column.property) { case "closeTime": sums[index] = this.closeList + ' h' break; case "machiningTime": sums[index] = this.machiningTimeList + ' h' break; case "stopTime": sums[index] = this.stopTimeList + ' h' break; case "debugTime": sums[index] = this.debugTimeList + ' h' break; default: break; } }); return sums; },
效果图:
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
今天给大家分享的是用vue怎样实现表格自定义列的效果,如果是做crm系统的朋友,应该常会遇到这样的需求,也就是用户可以按设置好的字段自定义排序或显示或隐藏表格的列,接下来我们详细了解看看这是怎样实现的吧。
本文实例为大家分享了js实现按钮进行某行上移下移的具体代码,供大家参考,具体内容如下先上个通用简单的代码:<!DOCTYPE html><html><head><meta charset="utf-8"><meta http-eq
这篇文章给大家分享的是jQuery如何实现图片隐藏和显示的一个示例,文中示例是实现一张图片慢慢消失隐藏后,显示另一种图片的效果,那么具体怎样实现呢?文中的示例介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
JS沙箱的实现方法有哪些?在微前端领域当中,沙箱是很重要的一件事情,下文会给大家介绍iframe实现沙箱、diff方式实现沙箱、基于代理(Proxy)实现单实例沙箱和基于代理(Proxy)实现多实例沙箱这四种JS沙箱的实现方法,感兴趣的朋友就继续往下看吧。
React是用于构建用户界面的JavaScript库,本文主要介绍了如何创建自己的第一个React页面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008