vue2的 element 表格单元格合并

  1. <template>
  2. <div>
  3. <el-table show-summary :summary-method="getSummaries" :span-method="objectSpanMethod" :data="tableData" row-key="id" ref="tableDom" border>
  4. <el-table-column label="序号" width="55" align="center">
  5. <template slot-scope="scope">{{ scope.$index + 1 }}</template>
  6. </el-table-column>
  7. <el-table-column prop="name" label="分类" align="center"></el-table-column>
  8. <el-table-column prop="num1" label="数量1" align="center"></el-table-column>
  9. <el-table-column prop="num2" label="数量2" align="center"></el-table-column>
  10. <el-table-column prop="num3" label="数量3" align="center"></el-table-column>
  11. <el-table-column prop="type" label="类型" align="center"></el-table-column>
  12. <el-table-column prop="num4" label="数量4" align="center"></el-table-column>
  13. <el-table-column prop="num5" label="数量5" align="center"></el-table-column>
  14. </el-table>
  15. </div>
  16. </template>
  17. <script>
  18. export default {
  19. name: '',
  20. components: {},
  21. props: {},
  22. data() {
  23. return {
  24. tableData: [{
  25. name: '名称1',
  26. num1: '2',
  27. num2: '3',
  28. num3: '4',
  29. num4: '连续',
  30. num5: '6',
  31. num6: '7',
  32. }, {
  33. name: '名称2',
  34. num1: '2',
  35. num2: '3',
  36. num3: '4',
  37. num4: '连续',
  38. num5: '6',
  39. num6: '7',
  40. }, {
  41. name: '名称2',
  42. num1: '2',
  43. num2: '3',
  44. num3: '4',
  45. num4: '连续',
  46. num5: '6',
  47. num6: '7',
  48. }, {
  49. name: '名称3',
  50. num1: '2',
  51. num2: '3',
  52. num3: '4',
  53. num4: '连续',
  54. num5: '6',
  55. num6: '7',
  56. }, {
  57. name: '名称4',
  58. num1: '2',
  59. num2: '3',
  60. num3: '4',
  61. num4: '连续',
  62. num5: '6',
  63. num6: '7',
  64. }, {
  65. name: '名称4',
  66. num1: '2',
  67. num2: '3',
  68. num3: '4',
  69. num4: '连续',
  70. num5: '6',
  71. num6: '7',
  72. }]
  73. }
  74. },
  75. filters: {},
  76. computed: {},
  77. watch: {},
  78. created() {},
  79. mounted() {},
  80. beforeDestroy() {},
  81. methods: {
  82. // 合计
  83. getSummaries (param) {
  84. const { columns, data } = param
  85. const sums = \[\]
  86. columns.forEach((column, index) => {
  87. if (index === 0) {
  88. sumsindex = '合计'
  89. } else if (index === 2 || index === 7) {
  90. const values = data.map(item => Number(itemcolumn.property))
  91. if (!values.every(value => isNaN(value))) {
  92. sumsindex = values.reduce((prev, curr) => {
  93. const value = Number(curr)
  94. if (!isNaN(value)) {
  95. return prev + curr
  96. } else {
  97. return prev
  98. }
  99. }, 0)
  100. } else {
  101. sumsindex = ''
  102. }
  103. } else {
  104. sumsindex = ''
  105. }
  106. })
  107. return sums
  108. },
  109. // table合并列
  110. objectSpanMethod({ row, column, rowIndex, columnIndex }) {
  111. let data = this.tableData; //拿到当前table中数据
  112. let cellValue = rowcolumn.property; //当前位置的值
  113. let noSortArr = 'num1', 'num2', 'num3', 'num4', 'num5', 'num6'; //不需要合并的字段(不进行合并行的prop)
  114. if (cellValue && !noSortArr.includes(column.property)) {
  115. let prevRow = datarowIndex - 1; //获取到上一条数据
  116. let nextRow = datarowIndex + 1; //下一条数据
  117. if (prevRow && prevRowcolumn.property === cellValue) { //当有上一条数据,并且和当前值相等时
  118. return { rowspan: 0, colspan: 0 };
  119. } else {
  120. let countRowspan = 1;
  121. while (nextRow && nextRowcolumn.property === cellValue) { //当有下一条数据并且和当前值相等时,获取新的下一条
  122. nextRow = data++countRowspan + rowIndex;
  123. }
  124. if (countRowspan > 1) {
  125. return { rowspan: countRowspan, colspan: 1 };
  126. }
  127. }
  128. }
  129. },
  130. }
  131. }
  132. </script>
  133. <style scoped lang="less">
  134. </style>
相关推荐
Darling噜啦啦10 分钟前
JavaScript 数组深度解析:从纯函数到二维数组陷阱,一文吃透前端数据结构核心
前端·javascript·数据结构
万少10 分钟前
一封邮件,让我重新打开了搁置半年的鸿蒙应用
前端·javascript·后端
To_OC33 分钟前
从一段定时器代码,重新捋清 JS 同步、异步与 Promise
前端·javascript·代码规范
拙慕JULY1 小时前
小程序返回 base64 文件报错
开发语言·javascript·小程序
数据知道1 小时前
字体与排版防线:ClientRects 与系统字体枚举的底层拦截与伪造
javascript·数据采集·指纹浏览器·风控·浏览器指纹
小二·1 小时前
Spring Boot 3 + Vue 3 全栈开发实战
vue.js·spring boot·后端
阿猫的故乡1 小时前
Vue组合式函数(Composables)从入门到实战:鼠标跟踪、请求封装、本地存储……全案例拆解
前端·vue.js·计算机外设
一壶纱1 小时前
一个用于 UniApp 项目的 Pinia 持久化插件
前端·javascript·vue.js
凌涘1 小时前
JS 八大基本类型:一场内存视角的冒险之旅
前端·javascript
数据知道1 小时前
视觉伪装(上):Canvas 指纹生成原理与 Skia 图形库底层注入噪声
开发语言·javascript·ecmascript·数据采集·指纹浏览器