跨多列,多行表头的DataGrid
来源:互联网 发布:数据库理论试题及答案 编辑:程序博客网 时间:2024/04/20 23:33
在网上搜索了半天,有以下几个方法:
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 版权归原作者所有
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 版权归原作者所有
- 创建跨多列、多行表头的DataGrid
- 创建跨多列、多行表头的DataGrid
- 创建跨多列、多行表头的DataGrid
- 创建跨多列、多行表头的DataGrid
- 创建跨多列、多行表头的DataGrid
- 创建跨多列、多行表头的DataGrid
- 创建跨多列、多行表头的DataGrid
- 跨多列,多行表头的DataGrid
- 创建跨多列、多行表头的DataGrid(补全版)
- DataGrid多行表头不影响排序的实现
- 关于创建跨多列、多行表头的DataGrid的一些问题
- DataGrid表头跨行合并的实现
- DataGrid表头跨行合并的实现
- DataGrid表头跨行合并的实现
- Flex中DataGrid多表头的实现
- Flex中DataGrid多表头的实现
- 固定表头的DataGrid
- silverlight - dataGrid多表头
- 披着羊皮的狼
- C#的四中排序方法
- C#处理文本文件
- 接到LZZ的电话,心情很糟糕.
- DataGrid导入Excel
- 跨多列,多行表头的DataGrid
- .Net中的DBNull类型
- 分页控件[陕北吴旗娃的AspNetPager控件]
- 给定一个字段的值,查询它所处的表以及字段
- ##---玩死小泉--##
- 一个文件上传与下载的UserControl
- 一个略有特殊的Update的语句.
- 今天下午很郁闷
- 两个CheckBox互动