分享
 
 
 

ASP.NET 2.0中合并 GridView 的表头单元格

王朝asp·作者佚名  2006-12-11
窄屏简体版  字體: |||超大  

在实际工作中,往往需要合并表格头部的单元格,下面就是一个实现的例子。运行结果如图:

C#

<%...@ Page Language="C#" AutoEventWireup="true" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"

"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<script runat="server">...

ICollection CreateDataSource()

...{

System.Data.DataTable dt = new System.Data.DataTable();

System.Data.DataRow dr;

dt.Columns.Add(new System.Data.DataColumn("学生姓名", typeof(System.String)));

dt.Columns.Add(new System.Data.DataColumn("语文", typeof(System.Decimal)));

dt.Columns.Add(new System.Data.DataColumn("数学", typeof(System.Decimal)));

dt.Columns.Add(new System.Data.DataColumn("英语", typeof(System.Decimal)));

for (int i = 0; i < 8; i++)

...{

System.Random rd = new System.Random(Environment.TickCount * i); ;

dr = dt.NewRow();

dr[0] = "学生" + i.ToString();

dr[1] = System.Math.Round(rd.NextDouble() * 100, 2);

dr[2] = System.Math.Round(rd.NextDouble() * 100, 2);

dr[3] = System.Math.Round(rd.NextDouble() * 100, 2);

dt.Rows.Add(dr);

}

System.Data.DataView dv = new System.Data.DataView(dt);

return dv;

}

protected void Page_Load(object sender, EventArgs e)

...{

if (!IsPostBack)

...{

GridView1.BorderColor = System.Drawing.Color.DarkOrange;

GridView1.DataSource = CreateDataSource();

GridView1.DataBind();

}

}

protected void GridView1_RowCreated(object sender, GridViewRowEventArgs e)

...{

if (e.Row.RowType == DataControlRowType.Header)

...{

GridViewRow rowHeader = new GridViewRow(0, 0, DataControlRowType.Header, DataControlRowState.Normal);

rowHeader.BackColor = System.Drawing.Color.White;

rowHeader.Font.Bold = true;

TableCellCollection cells = e.Row.Cells;

TableCell headerCell = new TableCell();

headerCell.Text = "";

rowHeader.Cells.Add(headerCell);

headerCell = new TableCell();

headerCell.Text = "学生成绩";

headerCell.ColumnSpan = cells.Count - 1;

headerCell.HorizontalAlign = HorizontalAlign.Center;

rowHeader.Cells.Add(headerCell);

rowHeader.Visible = true;

GridView1.Controls[0].Controls.AddAt(0, rowHeader);

}

}

protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)

...{

e.Row.Attributes.Add("style", "background:#FFF");

}

</script>

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<title>合并 GridView 的表头单元格</title>

</head>

<body>

<form id="Form1" runat="server">

<asp:GridView ID="GridView1" runat="server" CellSpacing="1" CellPadding="3"

Font-Size="12px" Width="300px" BackColor="orange" BorderWidth="0"

OnRowDataBound="GridView1_RowDataBound" OnRowCreated="GridView1_RowCreated">

</asp:GridView>

</form>

</body>

</html>

VB.NET

<%...@ Page Language="VB" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<script runat="server">...

Function CreateDataSource() As ICollection

Dim dt As System.Data.DataTable = New System.Data.DataTable

Dim dr As System.Data.DataRow

dt.Columns.Add(New System.Data.DataColumn("学生姓名", GetType(System.String)))

dt.Columns.Add(New System.Data.DataColumn("语文", GetType(System.Decimal)))

dt.Columns.Add(New System.Data.DataColumn("数学", GetType(System.Decimal)))

dt.Columns.Add(New System.Data.DataColumn("英语", GetType(System.Decimal)))

Dim i As Integer = 0

For i = 0 To 7

Dim rd As System.Random = New System.Random(Environment.TickCount * i)

dr = dt.NewRow

dr(0) = "学生" + i.ToString

dr(1) = System.Math.Round(rd.NextDouble * 100, 2)

dr(2) = System.Math.Round(rd.NextDouble * 100, 2)

dr(3) = System.Math.Round(rd.NextDouble * 100, 2)

dt.Rows.Add(dr)

Next

Dim dv As System.Data.DataView = New System.Data.DataView(dt)

Return dv

End Function

Protected Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs)

If Not IsPostBack Then

GridView1.BorderColor = System.Drawing.Color.DarkOrange

GridView1.DataSource = CreateDataSource()

GridView1.DataBind()

End If

End Sub

Protected Sub GridView1_RowCreated(ByVal sender As Object, ByVal e As GridViewRowEventArgs)

If e.Row.RowType = DataControlRowType.Header Then

Dim rowHeader As GridViewRow = New GridViewRow(0, 0, DataControlRowType.Header, DataControlRowState.Normal)

rowHeader.BackColor = System.Drawing.Color.White

rowHeader.Font.Bold = True

Dim cells As TableCellCollection = e.Row.Cells

Dim headerCell As TableCell = New TableCell

headerCell.Text = ""

rowHeader.Cells.Add(headerCell)

headerCell = New TableCell

headerCell.Text = "学生成绩"

headerCell.ColumnSpan = cells.Count - 1

headerCell.HorizontalAlign = HorizontalAlign.Center

rowHeader.Cells.Add(headerCell)

rowHeader.Visible = True

GridView1.Controls(0).Controls.AddAt(0, rowHeader)

End If

End Sub

Protected Sub GridView1_RowDataBound(ByVal sender As Object, ByVal e As GridViewRowEventArgs)

e.Row.Attributes.Add("style", "background:#FFF")

End Sub

</script>

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<title>合并 GridView 的表头单元格</title>

</head>

<body>

<form id="Form1" runat="server">

<asp:GridView ID="GridView1" runat="server" CellSpacing="1" CellPadding="3"

Font-Size="12px" Width="300px" BackColor="orange" BorderWidth="0"

OnRowDataBound="GridView1_RowDataBound" OnRowCreated="GridView1_RowCreated">

</asp:GridView>

</form>

</body>

</html>

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有