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 合并单元格:如何实现部分成功部分失败的效果?的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月22日 04:57:36
下一篇 2025年12月22日 04:57:43

相关推荐

发表回复

登录后才能评论
关注微信