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. sums[index] = '合计'
  89. } else if (index === 2 || index === 7) {
  90. const values = data.map(item => Number(item[column.property]))
  91. if (!values.every(value => isNaN(value))) {
  92. sums[index] = 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. sums[index] = ''
  102. }
  103. } else {
  104. sums[index] = ''
  105. }
  106. })
  107. return sums
  108. },
  109. // table合并列
  110. objectSpanMethod({ row, column, rowIndex, columnIndex }) {
  111. let data = this.tableData; //拿到当前table中数据
  112. let cellValue = row[column.property]; //当前位置的值
  113. let noSortArr = ['num1', 'num2', 'num3', 'num4', 'num5', 'num6']; //不需要合并的字段(不进行合并行的prop)
  114. if (cellValue && !noSortArr.includes(column.property)) {
  115. let prevRow = data[rowIndex - 1]; //获取到上一条数据
  116. let nextRow = data[rowIndex + 1]; //下一条数据
  117. if (prevRow && prevRow[column.property] === cellValue) { //当有上一条数据,并且和当前值相等时
  118. return { rowspan: 0, colspan: 0 };
  119. } else {
  120. let countRowspan = 1;
  121. while (nextRow && nextRow[column.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>

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在Ant Design Vue中,可以通过自定义渲染函数来实现表格合并单元格功能。具体的实现方法如下: 1. 首先,定义一个包含合并单元格逻辑的自定义渲染函数。在该函数中,可以通过设置`attrs`对象的`rowSpan`属性来指定需要合并的行数。例如,如果要合并某一列的前两行,可以设置`rowSpan: 2`。 2. 在表格的`columns`属性中,使用自定义渲染函数来控制需要合并单元格的列。在`customRender`属性中,返回一个包含`children`和`attrs`的对象,其中`children`表示单元格的内容,`attrs`表示单元格的属性。 下面是一个示例代码,演示了如何在Ant Design Vue中实现表格合并单元格功能: ```javascript const columns = \[ { title: 'Name', dataIndex: 'name', customRender: (value, row, index) => { const obj = { children: value, attrs: {}, }; if (index === 2) { obj.attrs.rowSpan = 2; } return obj; }, }, // 其他列的配置... \]; const data = \[ { name: 'John', age: 32 }, { name: 'Tom', age: 28 }, { name: 'Jerry', age: 25 }, { name: 'Alice', age: 30 }, \]; <Table :columns="columns" :dataSource="data" /> ``` 在上述代码中,通过设置`obj.attrs.rowSpan`来实现了对第三行和第四行的合并单元格操作。你可以根据自己的需求,修改`customRender`函数中的逻辑来实现更复杂的合并单元格操作。 #### 引用[.reference_title] - *1* [Ant Design Vue实现a-table表格单元格合并(列/行合并)](https://blog.csdn.net/a18792627168/article/details/108196198)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Ant design vue table 合并写法(详细代码-行合并)](https://blog.csdn.net/qq_43468165/article/details/122325234)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [ant design vue表格合并](https://blog.csdn.net/weixin_42812634/article/details/122727848)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值