vue + Element UI table动态合并单元格

一、功能需求

1、根据名称相同的合并工作阶段和主要任务合并这两列,但主要任务内容一样,但要考虑主要任务一样,但工作阶段不一样的情况。(枞向合并)

2、落实情况里的定量内容和定性内容值一样则合并。(横向合并)

二、功能实现

<template>

<div class="effect">

<el-table :data="tableData" border style="width: 100%" :span-method="objectSpanMethod">

<el-table-column type="index" label="序号" align="center" width="180">

</el-table-column>

<el-table-column prop="name" label="工作阶段" align="center" min-width="180">

</el-table-column>

<el-table-column prop="address" label="主要任务" align="center" min-width="180">

</el-table-column>

</el-table>

</div>

</template>

<script>

export default {

data () {

return {

tableData: [

{

name: 'a',

address: '1',

age:'1',

six:'2'

},

{

name: 'a',

address: '1',

age:'1',

six:'2'

},

{

name: 'a',

address: '1',

age:'1',

six:'2'

},

{

name: 'a',

address: '1',

age:'1',

six:'2'

},

{

name: 'a',

address: '2',

age:'1',

six:'2'

},

{

name: 'a',

address: '2',

age:'1',

six:'1'

},

{

name: 'a',

address: '3',

age:'1',

six:'1'

},

{

name: 'a',

address: '3',

age:'1',

six:'1'

},

{

name: 'b',

address: '3',

age:'1',

six:'1'

},

{

name: 'b',

address: '3',

age:'1',

six:'1'

},

{

name: 'b',

address: '3',

age:'1',

six:'1'

},

{

name: 'b',

address: '4',

age:'1',

six:'1'

},

{

name: 'b',

address: '4',

age:'1',

six:'1'

},

{

name: 'b',

address: '5',

age:'2',

six:'1'

},

{

name: 'b',

address: '5',

age:'',

six:''

},

]

}

},

mounted () {

// 处理第二列的合并

for (let i = 0; i < this.tableData.length; i++) {

//第一个单元格合并列为1

this.tableData[i].nameSpan = 1

//和后面值的比较,

for (let j = i+1; j < this.tableData.length; j++) {

//如果值一样,则合并列为+1

if(this.tableData[i].name != this.tableData[j].name){

//如果遇到值不一样,则将 i = k -1 因为 下次循环i会+1

i = j-1

// 结束循环

break;

}else{

this.tableData[i].nameSpan += 1

// 最后一行了,将k的值赋给i,结束循环

if(j == this.tableData.length-1){

i = j

// 结束循环

break;

}

}

}

}

// 处理第三列的合并

for (let i = 0; i < this.tableData.length; i++) {

//第一个单元格合并列为1

this.tableData[i].addressSpan = 1

//和后面值的比较,

for (let k = i+1; k < this.tableData.length; k++) {

//如果值一样,则合并列为+1

if(this.tableData[i].address == this.tableData[k].address && this.tableData[i].name == this.tableData[k].name){

this.tableData[i].addressSpan += 1

// 最后一行了,将k的值赋给i,结束循环

if(k == this.tableData.length-1){

i = k

// 结束循环

break;

}

}else{

//如果遇到值不一样,则将 i = k -1 因为 下次循环i会+1

i = k-1

// 结束循环

break;

}

}

}

// 处理第四列和第五列横向合并

for (let i = 0; i < this.tableData.length; i++) {

this.tableData[i].ageColspan = 1

if(this.tableData[i].age && this.tableData[i].six && this.tableData[i].age == this.tableData[i].six){

this.tableData[i].ageColspan += 1

}

}

console.log(this.tableData);

},

methods: {

//合并方法

objectSpanMethod ({ row, column, rowIndex, columnIndex }) {

if (columnIndex === 1) {

return {rowspan:row.nameSpan,colspan: 1}

}

if (columnIndex === 2) {

return {rowspan:row.addressSpan,colspan: 1}

}

if (columnIndex === 3) {

return {rowspan:1,colspan: row.ageColspan}

}

}

},

}

</script>

<style lang="scss" scoped>

.effect {

width: 100%;

height: calc(100vh - 90px);

padding: 5px;

}

</style>

相关推荐
腾讯TNTWeb前端团队5 小时前
helux v5 发布了,像pinia一样优雅地管理你的react状态吧
前端·javascript·react.js
范文杰8 小时前
AI 时代如何更高效开发前端组件?21st.dev 给了一种答案
前端·ai编程
拉不动的猪9 小时前
刷刷题50(常见的js数据通信与渲染问题)
前端·javascript·面试
拉不动的猪9 小时前
JS多线程Webworks中的几种实战场景演示
前端·javascript·面试
FreeCultureBoy9 小时前
macOS 命令行 原生挂载 webdav 方法
前端
uhakadotcom10 小时前
Astro 框架:快速构建内容驱动型网站的利器
前端·javascript·面试
uhakadotcom10 小时前
了解Nest.js和Next.js:如何选择合适的框架
前端·javascript·面试
uhakadotcom10 小时前
React与Next.js:基础知识及应用场景
前端·面试·github
uhakadotcom10 小时前
Remix 框架:性能与易用性的完美结合
前端·javascript·面试
uhakadotcom10 小时前
Node.js 包管理器:npm vs pnpm
前端·javascript·面试