Asp.Net下的DataGrid的多层表头
2005-09-10 16:48
260 查看
先看下表:
实际上Asp.Net下的DataGrid只不过是一个HtmlTable,只不过在HtmlTable的基础上添加了很多属性、方法,纳入ViewState机制,来生成、控制它;有了这一点认识,事情就很好办了:
我们可以在属性生成器中可以定义列的表头,它实际上只不过是在列之间插入了“</td><td>”的html标记,如此而已;因此根据上面的例子,可以在第3列的header里输入以下内容“</td></tr><TR><TD>北京</TD><TD>上海</TD><TD>深圳</TD></TR>”,这时你会发现2层表头就出现了:
但是显然还不够,因为我们还需要行、列的合并
我们可以在DataGrid的ItemDataBound事件中处理
if(e.Item.ItemType == ListItemType.Header)
{
e.Item.Cells[0].RowSpan = 2;
e.Item.Cells[1].ColumnSpan = 3;
e.Item.Cells[2].Visible = false;
e.Item.Cells[3].Visible = false;
}
实际上Asp.Net下的DataGrid只不过是一个HtmlTable,只不过在HtmlTable的基础上添加了很多属性、方法,纳入ViewState机制,来生成、控制它;有了这一点认识,事情就很好办了:
我们可以在属性生成器中可以定义列的表头,它实际上只不过是在列之间插入了“</td><td>”的html标记,如此而已;因此根据上面的例子,可以在第3列的header里输入以下内容“</td></tr><TR><TD>北京</TD><TD>上海</TD><TD>深圳</TD></TR>”,这时你会发现2层表头就出现了:
但是显然还不够,因为我们还需要行、列的合并
我们可以在DataGrid的ItemDataBound事件中处理
if(e.Item.ItemType == ListItemType.Header)
{
e.Item.Cells[0].RowSpan = 2;
e.Item.Cells[1].ColumnSpan = 3;
e.Item.Cells[2].Visible = false;
e.Item.Cells[3].Visible = false;
}
相关文章推荐
- Asp.Net下的DataGrid的多层表头(网友贴)
- asp.net的DataGrid的多层表头
- Asp.Net下的DataGrid的多层表头(网友贴) 选择自 yoyo83 的 Blog
- asp.net datagrid实现多层表头
- Asp.Net下的DataGrid的多层表头
- Asp.Net下的DataGrid的多层表头
- [zt]Asp.Net下的DataGrid的多层表头
- Asp.Net下的DataGrid的多层表头
- asp.net的DataGrid的多层表头
- Asp.Net下的DataGrid的多层表头(转自csdn)
- Asp.Net下的DataGrid的多层表头 (转)很简单的技巧
- asp.net的DataGrid的多层表头
- Asp.Net下的DataGrid的多层表头
- Asp.Net下的DataGrid的多层表头
- Asp.Net下的DataGrid的多层表头
- Asp.Net下的DataGrid的多层表头
- Net下的DataGrid的多层表头
- ASP.net(C#)导出Excel----普通表头,多层表头。
- ASP.NET中固定DataGrid的表头
- ASP.NET 2.0中GridView无限层复杂表头的实现(datagrid大同小易,repeater就不必这样,直接有头模版布局就可以)