el-table 合并单元格:如何实现部分成功部分失败的效果?

el-table 合并单元格:如何实现部分成功部分失败的效果?

el-table合并部分成功部分不成功

我们希望可以实现以下效果:

效果图

代码实现:

      {{scope.row.name }}                              
{{ scope.row.symbol }}

登录后复制

export default {  data() {    return {      tableData:[        {name:'降水(mm)',factor:'0.7',grade:'',symbol: '1','':'','':'','':'','':'','':'','':''},        {name:'降水(mm)',factor:'0.7',grade:'',symbol: '1','':'','':'','':'','':'','':'','':''},        {name:'降水(mm)',factor:'0.7',grade:'',symbol: '1','':'','':'','':'','':'','':'','':''},        {name:'降水(mm)',factor:'0.7',grade:'',symbol: '1','':'','':'','':'','':'','':'','':''},        {name:'风速(m/s)',factor:'0.5',grade:'',symbol: '0','':'','':'','':'','':'','':'','':''},        {name:'风速(m/s)',factor:'0.5',grade:'',symbol: '0','':'','':'','':'','':'','':'','':''},        {name:'风速(m/s)',factor:'0.5',grade:'',symbol: '0','':'','':'','':'','':'','':'','':''},        {name:'风速(m/s)',factor:'0.5',grade:'',symbol: '0','':'','':'','':'','':'','':'','':''},      ],      colFields:['name','factor','grade','symbol','','','','','',''],      spanArr:[],      waterForm:{},    };  },  methods: {    getSpanArr() {      for (let i = 0; i < this.tableData.length; i++) {        let row = i;        // let col = i % this.colCount;        if (row === 0) {          // i 表示行 j表示列          for (let j = 0; j < this.colFields.length; j++) {            this.spanArr[i * this.colFields.length + j] = {              rowspan: 1,              colspan: 1,            };          }        } else {          for (let j = 0; j < this.colFields.length; j++) {            if (              this.colFields[j] == "name" ||              this.colFields[j] == "factor" ||              this.colFields[j] == "symbol"            ) { // 指定合并哪些列            /*this.tableData[row]["School"] !==                  this.tableData[row - 1]["School"]*/              if (                this.tableData[row][this.colFields[j]] !==                  this.tableData[row - 1][this.colFields[j]]              ) { // 哪些不合并:School不一样的,不合并                this.spanArr[row * this.colFields.length + j] = {                  rowspan: 1,                  colspan: 1,                };              } else if (                this.tableData[row][this.colFields[j]] ===                this.tableData[row - 1][this.colFields[j]]              ) {                let beforeItem =                  this.spanArr[(row - 1) * this.colFields.length + j];                this.spanArr[row * this.colFields.length + j] = {                  rowspan: 1 + beforeItem.rowspan,// 合并几列                  colspan: 1,// 合并几行                };                beforeItem.rowspan = 0;                beforeItem.colspan = 0;              } else {                // rowspan 和 colspan 都为1表格此单元格不合并                this.spanArr[row * this.colFields.length + j] = {                  rowspan: 1,                  colspan: 1,                };              }            }          }        }      }      // 对数据进行倒序      let stack = [];      for (let i = 0; i < this.colFields.length; i++) {        for (let j = 0; j  0) {                let pop = stack.pop();                let len = stack.length;                this.spanArr[(j - len) * this.colFields.length + i] = pop;              }            }          }        }      }      // console.log(this.spanArr);    },    objectSpanMethod({ row, column, rowIndex, columnIndex }) {        return this.spanArr[rowIndex * this.colFields.length + columnIndex];    },  },  mounted() {    this.getSpanArr();  },};

登录后复制

注意,以上代码中,我们定义了 handleSpanM 方法来处理表格合并。但是,代码中并没有使用这个方法。你可以根据需要修改代码来使用这个方法。

此外,如果你希望后几列表头不可编辑,可以修改以下代码:


登录后复制

改成:


登录后复制

以上就是el-table 合并单元格:如何实现部分成功部分失败的效果?的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2800152.html

(0)
上一篇 2025年3月8日 21:02:45
下一篇 2025年3月8日 20:49:24

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论