展会信息港展会大全

Asp.net_Table控件之单元格纵向合并示例
来源:互联网   发布日期:2016-01-26 11:06:39   浏览:1971次  

导读:本文为大家介绍下如何实现动态生成表,同一列中数据相同的单元格需要合并,具体实现如下,由此需求的朋友可以参考下,希望对大家有所帮助业务需要,动态生成表,同一列中数据相同的单元格需要合并。解决方案,创 ...

本文为大家介绍下如何实现动态生成表,同一列中数据相同的单元格需要合并,具体实现如下,由此需求的朋友可以参考下,希望对大家有所帮助

业务需要,动态生成表,同一列中数据相同的单元格需要合并。

解决方案,创建Table控件处理类,代码如下:

复制代码 代码如下:

/// <summary>表格控件相关操作类

/// </summary>

public static class aspTable

{

/// <summary>合并行

/// </summary>

/// <remarks>版权信息:http://www.qqextra.com,http://t.qq.com/ls_man,http: //blog.csdn.net/ls_man 2013-06-21 14:20:36</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 = 0;

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 = 0;

spanRow = rowIndex--;

spanText = currentText;

}

}

//合并最后一项

tbl.Rows[spanRow].Cells[colIndex].RowSpan = countRowSpan;

}

/// <summary>合并行,支持多列

/// </summary>

/// <remarks><SPAN style="FONT-FAMILY: Arial, Helvetica, sans-serif">版权信息:http://www.qqextra.com,http://t.qq.com/ls_man,http: //blog.csdn.net/ls_man</SPAN><SPAN style="FONT-FAMILY: Arial, Helvetica, sans-serif"> 2013-06-21 15:24:34</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 - 1; i >= 0; i--)

{

SetRowSpan(tbl, startRow, endRow, (int)al[i]);

}

}

}

需要注意的几点,起始行一般设置为1,因为0是标题行;结束行一般设置为Table的总行数-1即可(最后一行)。

赞助本站

人工智能实验室

相关热词: 纵向合并 net Table控件

AiLab云推荐
展开

热门栏目HotCates

Copyright © 2010-2024 AiLab Team. 人工智能实验室 版权所有    关于我们 | 联系我们 | 广告服务 | 公司动态 | 免责声明 | 隐私条款 | 工作机会 | 展会港