elementui之table表格如何实现表头th的跨列合并

一、前言

这两天设计师给了一个table表格的原图,如下图:
表头 “项目名称“ 需要横跨2列PS:注意看红色圈起来的,表头“项目名称” 需要横跨2列
因为项目使用的是elementui的框架,表格用el-table已经渲染完成。居然在表头设置跨列的时候栽了跟头。

翻了官方文档,也没看到哪个属性跟方法与之相关;多少有点关系的就是多表头设置,可惜不符合。文档看不出来什么,只能靠度娘了,搜了半天全是与多表头相关的,最后看到了一篇操作dom元素的,才有了灵感。

二、代码奉上

<el-table
  v-loading="tableLoading"
  element-loading-background="rgba(40,43,50, 0)"
  :data="tableData"
  border
  :header-cell-class-name="theadSpan"
>
  <template slot="empty">
    <p>{{ tabelEmpty }}</p>
  </template>
  <el-table-column
    v-for="col in columns"
    :key="col.id"
    :prop="col.id"
    :label="col.label"
    :min-width="col.width"
  />
</el-table>

PS:

  1. 在data定义了columns变量存放表头数据
  2. 给table设置了header-cell-class-name属性,并通过theadSpan方法返回className(重点:这里跟表头跨列的有联系,可以往后看,有代码!!!!!!!!)
1.columns变量示例
data() {
	return {
	  columns: [
	    {
	      id: 'name',
	      label: '项目名称',
	      width: '100'
	    },
	    {
	      id: 'code',
	      label: '项目编码',
	      width: '100'
	    },
	    {
	      id: 'orgName',
	      label: '组织',
	      width: '100'
	    },
	    {
	      id: 'attributeName',
	      label: '项目属性',
	      width: '100'
	    },
	    {
	      id: 'online',
	      label: '是否上线',
	      width: '100'
	    },
	    {
	      id: 'comment',
	      label: '备注',
	      width: '100'
	    }
	  ]
	}
}
2.表头跨列实现(PS:重点!重点!重点!)
  1. 在method定义theadSpan方法
  2. dom渲染完成之后 执行setColSpan方法
mounted() {
  // dom渲染完成后 操作表头合并
  this.$nextTick(() => {
    this.setColSpan()
  })
},
methods: {
  setColSpan() {
    var x = document.querySelector('.colSpan')
    var x1 = document.querySelector('.hideTh')
    // 将第一列表头单元格的colSpan设为2
    x.colSpan = 2
    // 将第二列表头单元格的隐藏
    x1.style.display = 'none'
  },
  // 给第一列、第二列表头 返回 相应class
  theadSpan({ row, column, rowIndex, columnIndex }) {
    if (rowIndex === 0) {
    	// 给第一列表头的dom添加class='colSpan'
      if (columnIndex === 0) {
        return 'colSpan'
      }
      // 给第二列表头的dom添加class='hideTh'
      if (columnIndex === 1) {
        return 'hideTh'
      }
    }
  }
}
不重要的吐槽:

这样看,代码的确没多少就实现了功能,就是逼不得已,还需要操作dom元素才能完成。


总结

Element中table表格如何让表头跨列实现完成了,如果有其他方法,可以共享,相互学习~~~~

  • 5
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
实现 element-ui table 合并第二相同的数据,需要使用 `span-method` 属性和 `Table-column` 的 `prop` 属性。 首先,在 `Table` 组件中,使用 `span-method` 属性来定义合并规则: ```html <el-table :data="tableData" :span-method="mergeRows"> ... </el-table> ``` 然后,在 `methods` 中定义合并规则,可以使用 `row` 和 `column` 参数来获取当前单元格的行和信息,进而判断是否需要合并。 ```javascript methods: { mergeRows(row, column, rowIndex, columnIndex) { if (columnIndex === 1) { // 判断当前是否为第二 const rowSpan = this.getRowSpan(row, column, rowIndex, columnIndex); if (rowSpan === 1) { // 如果当前单元格不需要合并,返回 { rowspan: 1, colspan: 1 } return { rowspan: 1, colspan: 1 }; } else { // 如果当前单元格需要合并,返回 { rowspan: rowSpan, colspan: 1 } return { rowspan: rowSpan, colspan: 1 }; } } }, getRowSpan(row, column, rowIndex, columnIndex) { // 获取当前单元格的值 const currentValue = row[column.property]; // 定义合并行数 let rowSpan = 1; // 遍历当前的上方单元格 for (let i = rowIndex - 1; i >= 0; i--) { const prevRow = this.tableData[i]; // 如果上方单元格的值与当前单元格的值相等,行数加一 if (prevRow[column.property] === currentValue) { rowSpan++; } else { // 如果上方单元格的值与当前单元格的值不相等,停止遍历 break; } } return rowSpan; } } ``` 上面的代码中,`getRowSpan` 方法用来获取当前单元格需要合并的行数,遍历当前的上方单元格,如果上方单元格的值与当前单元格的值相等,则行数加一。最后,返回合并后的行数。 最后,还需要在第二的 `Table-column` 中设置 `prop` 属性,表示该的数据源来自于表格数据中的哪个字段。 ```html <el-table-column label="第二" prop="column2" /> ``` 这样,就可以实现 element-ui table 合并第二相同的数据了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值