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

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

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

熱門(mén)標(biāo)簽:阿里云 電子圍欄 銀行業(yè)務(wù) Mysql連接數(shù)設(shè)置 服務(wù)器配置 科大訊飛語(yǔ)音識(shí)別系統(tǒng) 團(tuán)購(gòu)網(wǎng)站 Linux服務(wù)器
(一)普通列
復(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)簽:衡水 衢州 江蘇 蚌埠 大理 廣元 萍鄉(xiāng) 棗莊

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《asp.net中GridView和DataGrid相同列合并實(shí)現(xiàn)代碼》,本文關(guān)鍵詞  ;如發(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)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢(xún)

    • 400-1100-266
    晋宁县| 武威市| 年辖:市辖区| 临颍县| 黄龙县| 清徐县| 南通市| 巴林左旗| 宝坻区| 陆丰市| 台中县| 淮滨县| 基隆市| 钟山县| 屏东市| 嘉定区| 竹溪县| 林芝县| 曲沃县| 都昌县| 浠水县| 玉门市| 鸡东县| 资阳市| 茶陵县| 保山市| 扶风县| 勐海县| 双江| 吴忠市| 县级市| 娄底市| 肇源县| 论坛| 会同县| 读书| 新野县| 牟定县| 广西| 肇州县| 凌源市|