这样看,代码的确没多少就实现了功能,就是逼不得已,还需要操作dom元素才能完成。
Element中table表格如何让表头跨列实现完成了,如果有其他方法,可以共享,相互学习~~~~
一、前言这两天设计师给了一个table表格的原图,如下图:PS:注意看红色圈起来的,表头“项目名称” 需要横跨2列因为项目使用的是elementui的框架,表格用el-table已经渲染完成。居然在表头设置跨列的时候栽了跟头。翻了官方文档,也没看到哪个属性跟方法与之相关;多少有点关系的就是多表头设置,可惜不符合。文档看不出来什么,只能靠度娘了,搜了半天全是与多表头相关的,最后看到了一篇操作dom元素的,才有了灵感。二、代码奉上<el-table v-loading="tableLoad
在最近的一个迭代上,有一个功能点是在表格中做一个合并单元格的效果。大致如下图
只有第一列合并行,跨行。合并的规则是纵向相邻的连续N行,如果id一致,则合并。
看到这个需求一开始我以为很简单,表格跨行.跨列,不就是设置rowspan 和colspan。于是我就把这个功能点放到最后来实现了。
等到真正去做的时候,查了一下element的文档,发现并没那么简单。需要自己动手去写一个方法设置每个单元格的rowspan和 colspan。 眼看要提测了,想偷懒的想借他山之石。于是在前端群里问了一下,又没人写过
vue+element用于pc后台管理系统比较多,所以后台管理系统一般以处理数据为主,数据结构的复杂程度变高,相对应的前端展示成本也提高,有些产品经理或许会要求表格跨行或跨列合并,如果你正在想怎么实现,那就接着往下看最新封装了一个表格合并和编辑插件:vue-split-table,戳一戳效果图
element的2.x
(注意是2.X...
一般使用<td>元素的colspan属性来实现单元格跨列操作,使用<td>元素的rowspan属性来实现单元格的跨行操作。colspan属性规定单元格可横跨的列数,所有浏览器都支持colspan属性。其取值为number,如下图所示:例如:<table border="1">
<tr>
<th>星期一</th>
在项目开发中表格的使用还是很频繁的,而其中难免会涉及到表格的跨行跨列行为。这是一次记使用element-ui的table组件加vue实现的表格跨行跨列实践。
首先是查看element的table组件的api:
查找element-ui的官方文档,找到组件的表属性,其他组件也一样。
比如要改表头行:
利用header-row-style 表头行的 style 的回调方法,也可以使用一个固定的 Object 为所有表头行设置一样的 Style。例子如下:
<el-table :header-cell-style="tableHeaderColor"></el-table>
方法二:通过在style标签里修改
如果不生效,可能是你全局定义了e
最近项目有个需求针对到el-table这个组件。自己也是第一次这样来使用,特写下这两篇文章,算是当做记录吧!如果是从第一次使用elementUI的话,可以移步另一篇文章作为参考~
产品需求样式
既想用elementUI的table样式和功能,简单的<tr><th><td>是不能满足的
在使用element-ui的el-table组件时,最普遍的做法就是使用el-table-column;其中columns对应el-table-column Att.
要实现 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 合并第二列相同的数据了。