主頁(yè) > 知識(shí)庫(kù) > asp.net中GridView和DataGrid相同列合并實(shí)現(xiàn)代碼

asp.net中GridView和DataGrid相同列合并實(shí)現(xiàn)代碼

熱門標(biāo)簽:保山電話外呼管理系統(tǒng)怎么用 太原外呼電銷機(jī)器人費(fèi)用 東莞語(yǔ)音電銷機(jī)器人排名 朝陽(yáng)市地圖標(biāo)注 淘寶地圖標(biāo)注如何做 蘇州銷售外呼系統(tǒng)預(yù)算 電話機(jī)器人廣告話術(shù) 使用智能電話機(jī)器人違法嗎 外呼系統(tǒng)用員工身份證
(一)普通列
復(fù)制代碼 代碼如下:

/// summary>
/// Gridview列的合并(普通列,不包含模板列)
/// 注意:1.GridView在綁定的時(shí)候進(jìn)行分組和排序,才能讓相同的行放在一起
/// 2.方法應(yīng)用的時(shí)機(jī),應(yīng)該在Gridview的DataBound事件中使用
/// /summary>
/// param name="gv">需要合并的GridView對(duì)象/param>
/// param name="columnIndex">所要合并列的索引/param>
public static void UnitCell(GridView gv, int columnIndex)
{
int i = 0; //當(dāng)前行數(shù)
string lastType = string.Empty; //當(dāng)前判斷是否合并行對(duì)應(yīng)列的值
int lastCell = 0; //判斷最后一個(gè)相同值的行的索引
if (gv.Rows.Count > 0)
{
lastType = gv.Rows[0].Cells[columnIndex].Text.ToString();
gv.Rows[0].Cells[columnIndex].RowSpan = 1;
lastCell = 0;
}
for (i = 1; i gv.Rows.Count; i++)
{
if (gv.Rows[i].Cells[columnIndex].Text == lastType)
{
gv.Rows[i].Cells[columnIndex].Visible = false;
gv.Rows[lastCell].Cells[columnIndex].RowSpan++;
}
else
{
lastType = gv.Rows[i].Cells[columnIndex].Text.ToString();
lastCell = i;
gv.Rows[i].Cells[columnIndex].RowSpan = 1;
}
}
}
/// summary>
/// DataGrid列的合并(普通列,不包含模板列)
/// 注意:1.DataGrid在綁定的時(shí)候進(jìn)行分組和排序,才能讓相同的行放在一起
/// 2.方法應(yīng)用的時(shí)機(jī),應(yīng)該在DataGrid的DataBound事件中使用
/// /summary>
/// param name="dg">需要合并的DataGrid對(duì)象/param>
/// param name="columnIndex">所要合并列的索引/param>
public static void UnitCell_T(DataGrid dg, int columnIndex)
{
int i = 0; //當(dāng)前行數(shù)
string lastType = string.Empty; //當(dāng)前判斷是否合并行對(duì)應(yīng)列的值
int lastCell = 0; //判斷最后一個(gè)相同值的行的索引
if (dg.Items.Count> 0)
{
lastType = dg.Items[0].Cells[columnIndex].Text.ToString();
dg.Items[0].Cells[columnIndex].RowSpan = 1;
lastCell = 0;
}
for (i = 1; i dg.Items.Count; i++)
{
if (dg.Items[i].Cells[columnIndex].Text == lastType)
{
dg.Items[i].Cells[columnIndex].Visible = false;
dg.Items[lastCell].Cells[columnIndex].RowSpan++;
}
else
{
lastType = dg.Items[i].Cells[columnIndex].Text.ToString();
lastCell = i;
dg.Items[i].Cells[columnIndex].RowSpan = 1;
}
}
}

(二)模板列
復(fù)制代碼 代碼如下:

/// summary>
/// Gridview列的合并(模板列)
/// /summary>
/// param name="gv">需要合并的GridView對(duì)象/param>
/// param name="columnIndex">所要合并列的索引/param>
/// param name="lblName">模板列對(duì)象的ID/param>
public static void UnitCell(GridView gv, int columnIndex, string lblName)
{
int i = 0; //當(dāng)前行數(shù)
string lastType = string.Empty; //當(dāng)前判斷是否合并行對(duì)應(yīng)列的值
int lastCell = 0; //判斷最后一個(gè)相同值的行的索引
if (gv.Rows.Count > 0)
{
lastType = (gv.Rows[0].Cells[columnIndex].FindControl(lblName) as Label).Text;
gv.Rows[0].Cells[columnIndex].RowSpan = 1;
lastCell = 0;
}
for (i = 1; i gv.Rows.Count; i++)
{
if ((gv.Rows[i].Cells[columnIndex].FindControl(lblName) as Label).Text == lastType)
{
gv.Rows[i].Cells[columnIndex].Visible = false;
gv.Rows[lastCell].Cells[columnIndex].RowSpan++;
}
else
{
lastType = (gv.Rows[i].Cells[columnIndex].FindControl(lblName) as Label).Text.ToString();
lastCell = i;
gv.Rows[i].Cells[columnIndex].RowSpan = 1;
}
}
}

(三)在DataBound事件中調(diào)用即可。

在GridView或DataGrid中顯示固定寬度的列

默認(rèn)情況下,Gridview和Datagrid控件依據(jù)它們的內(nèi)容自動(dòng)調(diào)整列大小。要為列指定固定寬度,設(shè)置每個(gè)Tablecell對(duì)象的Width屬性并設(shè)置Wrap屬性為False。下面的例子顯示了如何通過(guò)使用DataGrid控件去做。
復(fù)制代碼 代碼如下:

rotected void DataGrid1_ItemCreated(object sender, DataGridItemEventArgs e)
{
ListItemType lit = e.Item.ItemType;
if (lit == ListItemType.Header)
{
for (int i = 0; i e.Item.Cells.Count; i++)
{
e.Item.Cells[i].Width = Unit.Pixel(50);
e.Item.Cells[i].Wrap = false;
}
}
}
您可能感興趣的文章:
  • datalist,Repeater和Gridview的區(qū)別分析
  • asp.net中讓Repeater和GridView支持DataPager分頁(yè)
  • repeater、gridview 在綁定時(shí)判斷判斷顯示不同的行樣式或文本
  • ASP.NET MVC4之js css文件合并功能(3)
  • Asp.net程序優(yōu)化js、css實(shí)現(xiàn)合并與壓縮的方法
  • Asp.net_Table控件の單元格縱向合并示例
  • ASP.NET GridView 實(shí)現(xiàn)課程表顯示(動(dòng)態(tài)合并單元格)實(shí)現(xiàn)步驟
  • asp.net中rdlc 合并行的方法
  • asp.net 合并GridView中某列相同信息的行(單元格)
  • ASP.NET中GridView和Repeater重復(fù)數(shù)據(jù)如何合并

標(biāo)簽:呼倫貝爾 克拉瑪依 運(yùn)城 潛江 洛陽(yáng) 綏化 西藏 阿里

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net中GridView和DataGrid相同列合并實(shí)現(xiàn)代碼》,本文關(guān)鍵詞  asp.net,中,GridView,和,DataGrid,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《asp.net中GridView和DataGrid相同列合并實(shí)現(xiàn)代碼》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于asp.net中GridView和DataGrid相同列合并實(shí)現(xiàn)代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章