- <template>
- <div>
- <el-table show-summary :summary-method="getSummaries" :span-method="objectSpanMethod" :data="tableData" row-key="id" ref="tableDom" border>
- <el-table-column label="序号" width="55" align="center">
- <template slot-scope="scope">{{ scope.$index + 1 }}</template>
- </el-table-column>
- <el-table-column prop="name" label="分类" align="center"></el-table-column>
- <el-table-column prop="num1" label="数量1" align="center"></el-table-column>
- <el-table-column prop="num2" label="数量2" align="center"></el-table-column>
- <el-table-column prop="num3" label="数量3" align="center"></el-table-column>
- <el-table-column prop="type" label="类型" align="center"></el-table-column>
- <el-table-column prop="num4" label="数量4" align="center"></el-table-column>
- <el-table-column prop="num5" label="数量5" align="center"></el-table-column>
- </el-table>
- </div>
- </template>
- <script>
- export default {
- name: '',
- components: {},
- props: {},
- data() {
- return {
- tableData: [{
- name: '名称1',
- num1: '2',
- num2: '3',
- num3: '4',
- num4: '连续',
- num5: '6',
- num6: '7',
- }, {
- name: '名称2',
- num1: '2',
- num2: '3',
- num3: '4',
- num4: '连续',
- num5: '6',
- num6: '7',
- }, {
- name: '名称2',
- num1: '2',
- num2: '3',
- num3: '4',
- num4: '连续',
- num5: '6',
- num6: '7',
- }, {
- name: '名称3',
- num1: '2',
- num2: '3',
- num3: '4',
- num4: '连续',
- num5: '6',
- num6: '7',
- }, {
- name: '名称4',
- num1: '2',
- num2: '3',
- num3: '4',
- num4: '连续',
- num5: '6',
- num6: '7',
- }, {
- name: '名称4',
- num1: '2',
- num2: '3',
- num3: '4',
- num4: '连续',
- num5: '6',
- num6: '7',
- }]
- }
- },
- filters: {},
- computed: {},
- watch: {},
- created() {},
- mounted() {},
- beforeDestroy() {},
- methods: {
- // 合计
- getSummaries (param) {
- const { columns, data } = param
- const sums = []
- columns.forEach((column, index) => {
- if (index === 0) {
- sums[index] = '合计'
- } else if (index === 2 || index === 7) {
- 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] = ''
- }
- } else {
- sums[index] = ''
- }
- })
- return sums
- },
- // table合并列
- objectSpanMethod({ row, column, rowIndex, columnIndex }) {
- let data = this.tableData; //拿到当前table中数据
- let cellValue = row[column.property]; //当前位置的值
- let noSortArr = ['num1', 'num2', 'num3', 'num4', 'num5', 'num6']; //不需要合并的字段(不进行合并行的prop)
- if (cellValue && !noSortArr.includes(column.property)) {
- let prevRow = data[rowIndex - 1]; //获取到上一条数据
- let nextRow = data[rowIndex + 1]; //下一条数据
- if (prevRow && prevRow[column.property] === cellValue) { //当有上一条数据,并且和当前值相等时
- return { rowspan: 0, colspan: 0 };
- } else {
- let countRowspan = 1;
- while (nextRow && nextRow[column.property] === cellValue) { //当有下一条数据并且和当前值相等时,获取新的下一条
- nextRow = data[++countRowspan + rowIndex];
- }
- if (countRowspan > 1) {
- return { rowspan: countRowspan, colspan: 1 };
- }
- }
- }
- },
- }
- }
- </script>
- <style scoped lang="less">
- </style>

vue2的 element 表格单元格合并
luckycoke2023-07-22 16:02
相关推荐
追风筝的人er2 小时前
SpringBoot+Vue3 企业考勤如何处理法定假期?节假日方案、调休补班与工作日判断链路拆解编程老船长5 小时前
解决不同项目需要不同 Node.js 版本的问题薛定猫AI6 小时前
【深度解析】Gemma Chat 本地 AI 编程 Agent:Electron + MLX + 开源模型的离线 Vibe Coding 实战全栈前端老曹7 小时前
【前端地图】多地图平台适配方案——高德、百度、腾讯、Google Maps SDK 差异对比、封装统一地图接口笑虾7 小时前
Win10 修改注册表 让鼠标悬停PNG上时 tip 始终显示分辨率xiaogg36787 小时前
spring oauth2 单点登录雾岛听风6917 小时前
JavaScript基础语法速查手册前端那点事7 小时前
Vue前端SEO优化全攻略(实操落地版,新手也能上手)用户2367829801687 小时前
从零实现 GIF 制作工具:LZW 压缩与 Median Cut 色彩量化棉猴8 小时前
Python海龟绘图之绘制文本