在网上搜索了半天,有以下几个方法:
1. 孟子E章的 ()
隐藏DataGrid的表头,在DataGrid的上放画一个多行表头.
不方便的地方是::
a. 对齐表头与DataGrid各列,有点麻烦.
b. 如果我要把DataGrid(表头形式,数据内容)导进Excel,则不会看到多行表头(多行表头这里不属于DataGrid)
2. 直接更改DataGrid的表头样式
3.使用RenderMethod委托可以实现DataGrid表头的合并,DataGrid的表头转化为用Table来控制
请参照:http://terrylee.cnblogs.com/archive/2005/09/29/246576.aspx
1. 孟子E章的 ()
隐藏DataGrid的表头,在DataGrid的上放画一个多行表头.
不方便的地方是::
a. 对齐表头与DataGrid各列,有点麻烦.
b. 如果我要把DataGrid(表头形式,数据内容)导进Excel,则不会看到多行表头(多行表头这里不属于DataGrid)
2. 直接更改DataGrid的表头样式
3.使用RenderMethod委托可以实现DataGrid表头的合并,DataGrid的表头转化为用Table来控制
请参照:http://terrylee.cnblogs.com/archive/2005/09/29/246576.aspx
/// <summary>
/// 创建Item
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void DataGrid_Total_ItemCreated(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
{
//将Item的呈现方法定向到自定义的呈现方法上
ListItemType lit = e.Item.ItemType;
if(ListItemType.Header == lit)
{
e.Item.SetRenderMethodDelegate(new RenderMethod(NewRenderMethod));
}
}
/// <summary>
/// 自定义的Item呈现方法
/// </summary>
/// <param name="writer"></param>
/// <param name="ctl"></param>
private void NewRenderMethod(HtmlTextWriter writer,Control ctl)
{
//不需要从<TR>标签开始
//第一列"表号",必须有rowspan属性
TableCell cell1 = (TableCell)ctl.Controls[0];
cell1.Attributes.Add("rowspan","2");
cell1.Attributes.Add("align","center");
cell1.RenderControl(writer);
//输出“电度表”列
writer.Write("<TD colspan=\"4\" rowspan=\"1\" align=\"center\">电度表</TD>\n");
//“月末核算(度)”列必须有rowspan属性
TableCell cell = (TableCell)ctl.Controls[ctl.Controls.Count - 1];
cell.Attributes.Add("rowspan","2");
cell.Attributes.Add("align","center");
cell.RenderControl(writer);
//现在关闭第一行
writer.Write("</TR>\n");
//将设计时的样式属性添加到第二行使得两行的外观相似
this.DataGrid_Total.HeaderStyle.AddAttributesToRender(writer);
//插入第二行
writer.RenderBeginTag("TR");
//呈现除了最后一列(刚才已经呈现过了)外的所有在设计时定义的cells
for(int i=1;i<=ctl.Controls.Count-2;i++)
{
ctl.Controls[i].RenderControl(writer);
}
//不需要以</TR>结束
}
/// 创建Item
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void DataGrid_Total_ItemCreated(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
{
//将Item的呈现方法定向到自定义的呈现方法上
ListItemType lit = e.Item.ItemType;
if(ListItemType.Header == lit)
{
e.Item.SetRenderMethodDelegate(new RenderMethod(NewRenderMethod));
}
}
/// <summary>
/// 自定义的Item呈现方法
/// </summary>
/// <param name="writer"></param>
/// <param name="ctl"></param>
private void NewRenderMethod(HtmlTextWriter writer,Control ctl)
{
//不需要从<TR>标签开始
//第一列"表号",必须有rowspan属性
TableCell cell1 = (TableCell)ctl.Controls[0];
cell1.Attributes.Add("rowspan","2");
cell1.Attributes.Add("align","center");
cell1.RenderControl(writer);
//输出“电度表”列
writer.Write("<TD colspan=\"4\" rowspan=\"1\" align=\"center\">电度表</TD>\n");
//“月末核算(度)”列必须有rowspan属性
TableCell cell = (TableCell)ctl.Controls[ctl.Controls.Count - 1];
cell.Attributes.Add("rowspan","2");
cell.Attributes.Add("align","center");
cell.RenderControl(writer);
//现在关闭第一行
writer.Write("</TR>\n");
//将设计时的样式属性添加到第二行使得两行的外观相似
this.DataGrid_Total.HeaderStyle.AddAttributesToRender(writer);
//插入第二行
writer.RenderBeginTag("TR");
//呈现除了最后一列(刚才已经呈现过了)外的所有在设计时定义的cells
for(int i=1;i<=ctl.Controls.Count-2;i++)
{
ctl.Controls[i].RenderControl(writer);
}
//不需要以</TR>结束
}