佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > Asp.net_Table控件の單元格縱向合并示例

Asp.net_Table控件の單元格縱向合并示例

熱門標簽:國美全國運營中心 網(wǎng)站排名優(yōu)化 人工智能 客戶服務 電商新玩法 電銷業(yè)務 百度AI接口 科大訊飛語音識別系統(tǒng)

業(yè)務需要,動態(tài)生成表,同一列中數(shù)據(jù)相同的單元格需要合并。
解決方案,創(chuàng)建Table控件處理類,代碼如下:

復制代碼 代碼如下:

/// summary>表格控件相關(guān)操作類
/// /summary>
public static class aspTable
{
/// summary>合并行
/// /summary>
/// remarks>版權(quán)信息: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">結(jié)束行/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;
//內(nèi)容是否相同
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">版權(quán)信息: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">結(jié)束行/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是標題行;結(jié)束行一般設置為Table的總行數(shù)-1即可(最后一行)。

您可能感興趣的文章:
  • datalist,Repeater和Gridview的區(qū)別分析
  • asp.net中讓Repeater和GridView支持DataPager分頁
  • repeater、gridview 在綁定時判斷判斷顯示不同的行樣式或文本
  • ASP.NET MVC4之js css文件合并功能(3)
  • Asp.net程序優(yōu)化js、css實現(xiàn)合并與壓縮的方法
  • ASP.NET GridView 實現(xiàn)課程表顯示(動態(tài)合并單元格)實現(xiàn)步驟
  • asp.net中GridView和DataGrid相同列合并實現(xiàn)代碼
  • asp.net中rdlc 合并行的方法
  • asp.net 合并GridView中某列相同信息的行(單元格)
  • ASP.NET中GridView和Repeater重復數(shù)據(jù)如何合并

標簽:益陽 攀枝花 棗莊 咸寧 廈門 POS機 拉薩 南平

巨人網(wǎng)絡通訊聲明:本文標題《Asp.net_Table控件の單元格縱向合并示例》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡,涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    栾川县| 彭水| 大悟县| 鲁山县| 得荣县| 徐水县| 三门峡市| 酉阳| 泰宁县| 棋牌| 宝兴县| 肥城市| 泰和县| 辽宁省| 康马县| 周口市| 确山县| 正蓝旗| 菏泽市| 永宁县| 通许县| 沂水县| 大庆市| 青冈县| 通江县| 揭西县| 滦南县| 泗洪县| 淳安县| 韶山市| 江永县| 英山县| 富裕县| 满洲里市| 新巴尔虎右旗| 九寨沟县| 自贡市| 长丰县| 钦州市| 东乌| 永春县|