本文为大家介绍下如何实现动态生成表
同一列中数据相同的单元格需要合并
具体实现如下
由此需求的朋友可以参考下
希望对大家有所帮助
业务需要动态生成表同一列中数据相同的单元格需要合并
解决方案创建Table控件处理类代码如下
复制代码 代码如下:
/// <summary>表格控件相关操作类
/// </summary>
public static class aspTable
{
/// <summary>合并行
/// </summary>
/// <remarks>版权信息
:
:
</remarks>
/// <param name="tbl">Table</param>
/// <param name="startRow">起始行</param>
/// <param name="endRow">结束行</param>
/// <param name="colIndex">要合并的列索引</param>
public static void SetRowSpan(Table tbl
int startRow
int endRow
int colIndex)
{
int countRowSpan =
;
int spanRow = startRow;
string spanText = tbl
Rows[startRow]
Cells[colIndex]
Text;
for (int rowIndex = startRow; rowIndex <= endRow; rowIndex++)
{
string currentText = tbl
Rows[rowIndex]
Cells[colIndex]
Text;
//内容是否相同
if (currentText == spanText)
{
countRowSpan++;
//移除被合并的单元格
if (rowIndex != spanRow)
{
tbl
Rows[rowIndex]
Cells
RemoveAt(colIndex);
}
}
else
{
//合并
tbl
Rows[spanRow]
Cells[colIndex]
RowSpan = countRowSpan;
//从此行再向下比较(重置)
countRowSpan =
;
spanRow = rowIndex
;
spanText = currentText;
}
}
//合并最后一项
tbl
Rows[spanRow]
Cells[colIndex]
RowSpan = countRowSpan;
}
/// <summary>合并行
支持多列
/// </summary>
/// <remarks><SPAN style="FONT
FAMILY: Arial
Helvetica
sans
serif">版权信息
: Arial
Helvetica
sans
serif">
:
:
</remarks></SPAN>
/// <param name="tbl">Table</param>
/// <param name="startRow">起始行</param>
/// <param name="endRow">结束行</param>
/// <param name="colIndex">要合并的列索引</param>
public static void SetRowSpans(Table tbl
int startRow
int endRow
params int[] colIndexs)
{
ArrayList al = new ArrayList(colIndexs);
al
Sort();
for (int i = al
Count
; i >=
; i
)
{
SetRowSpan(tbl
startRow
endRow
(int)al[i]);
}
}
}
需要注意的几点起始行一般设置为因为是标题行结束行一般设置为Table的总行数即可(最后一行)