js实现表格table相同列合并

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> 
<HTML> 
<HEAD> 
<TITLE> New Document </TITLE> 
<META NAME="Generator" CONTENT="EditPlus"> 
<META NAME="Author" CONTENT=""> 
<META NAME="Keywords" CONTENT=""> 
<META NAME="Description" CONTENT=""> 
</HEAD> 
<SCRIPT LANGUAGE="JavaScript"> 
function autoRowSpan(tb,row,col) { 
var lastValue=""; 
var value=""; 
var pos=1; 
for(var i=row;i<tb.rows.length;i++){ 
value = tb.rows[i].cells[col].innerText; 
if(lastValue == value){ 
tb.rows[i].deleteCell(col); 
tb.rows[i-pos].cells[col].rowSpan = tb.rows[i-pos].cells[col].rowSpan+1; 
pos++; 
}else{ 
lastValue = value; 
pos=1; 


}

function autoRowSpan1(tb,row,col) { 
var lastValue=""; 
var value=""; 
var pos=1;
var increase = 0;
for(var i=row;i<tb.rows.length;i++){ 
value = tb.rows[i].cells[col].innerText; 
if(lastValue == value){ 
tb.rows[i].deleteCell(col); 
tb.rows[i-pos].cells[col].rowSpan = tb.rows[i-pos].cells[col].rowSpan+1; 
//合并序列行
tb.rows[i].deleteCell(col-1);
tb.rows[i-pos].cells[col-1].rowSpan = tb.rows[i-pos].cells[col-1].rowSpan+1;
pos++; 
}else{ 
lastValue = value; 
pos=1; 
//合并序列行
if(i==1){
tb.rows[1].cells[0].innerText=1;
}else{
increase++;
tb.rows[i].cells[col-1].innerText= parseInt(tb.rows[1].cells[0].innerText)+parseInt(increase);
}


}

</SCRIPT> 
<BODY οnlοad="autoRowSpan1(tb,1,1)"> 
<TABLE id="tb" border="1"> 
<THEAD> 
<TR >
<TD align="center">序号</TD>
<TD>国家</TD> 
<TD>地区</TD> 
</TR> 
</THEAD> 
<TR>
<TD align="center">1</TD>
<TD>中国</TD> 
<TD>河南</TD> 
</TR> 
<TR>
<TD align="center">2</TD>
<TD>中国</TD> 
<TD>四川</TD> 
</TR> 
<TR>
<TD align="center">3</TD>
<TD>中国</TD> 
<TD>北京</TD> 
</TR> 
<TR>
<TD align="center">4</TD>
<TD>美国</TD> 
<TD>纽约</TD> 
</TR> 
<TR>
<TD align="center">5</TD>
<TD>美国</TD> 
<TD>洛杉矶</TD> 
</TR> 
<TR>
<TD align="center">6</TD>
<TD>英国</TD> 
<TD>伦敦</TD> 
</TR> 
</TABLE> 
</BODY> 
</HTML> 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现 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 合并第二相同的数据了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值