`
ihuashao
  • 浏览: 4544791 次
  • 性别: Icon_minigender_1
  • 来自: 济南
社区版块
存档分类
最新评论

GridView多行合并表头的实现

阅读更多

表格的多行复合表头是在开发中经常遇到的问题,怎么扩展GridView控件以实现多行表头呢

主体思路是这样的,GridView在ASP.NET中最终是转化为html的表格格式来显示的,所以我们要在其中做点文章,
看下面这段代码:
//在GridView的RowCreated事件中重写表头
protected void GridView1_RowCreated(object sender, GridViewRowEventArgs e)
{
判断创建的行是不是标题行
if (e.Row.RowType == DataControlRowType.Header)
{
TableCellCollection tcl = e.Row.Cells;
//清除自动生成的表头
tcl.Clear();

//添加新的表头
tcl.Add(new TableHeaderCell());
tcl[0].RowSpan = 2;
tcl[0].Text = "标题s";
Label l1 = new Label();
l1.Text = "uu";
Button bt = new Button();
bt.Text = "1";
//因为自定义表头,所以原来系统中实现的排序功能就失效了
//下面语句可以自己在表头中添加控件,自己实现排序功能

tcl[0].Controls.Add(l1);
tcl[0].Controls.Add(bt);

tcl.Add(new TableHeaderCell());
tcl[1].ColumnSpan = 2;
tcl[1].Text = "标题2";

tcl.Add(new TableHeaderCell());
tcl[2].RowSpan = 2;
tcl[2].Text = "标题3";

tcl.Add(new TableHeaderCell());
tcl[3].ColumnSpan = 3;
tcl[3].Text = "标题4";

tcl.Add(new TableHeaderCell());
tcl[4].RowSpan = 2;
//这段是重点 其实在生成的html中tcl[4]转化为<th>标题5</th>
//所以依照该原则注入html标签来实现,原理有些类似于SQL注入攻击

tcl[4].Text = "标题5</th></tr><tr><th>标题2-1</th><th>标题2-2</th><th>标题4-1</th><th>标题4-2</th><th>标题4-3";


}
}


分享到:
评论

相关推荐

    GridView动态创建列头丶自定义多行合并表头

    GridView动态创建列头丶自定义多行合并表头GridView动态创建列头丶自定义多行合并表头

    asp.net合并表头,实现多行表头

    GridView合并表头,实现多行表头,首行合并表头

    devexpress实现多行表头(复合表头)

    许多统计报表中都会涉及到复合表头的实现,最近写了一个复合表头的实例,与大家分享。

    GridView合并表头并且有合计

    大家都知道Gridview的合并是比较难的,此实例中把Gridview的单元格轻松合并,多行合并,特别是对于那些要合计的表单有灰常大的作用,代码都在后台控制,没有用前台代码控制表头合并。

    实现GridView多表头,表头合并,表头分组,支持多行

    朋友们使用过程中发现问题告诉我,写了半天了,我赚点辛苦分,嘿嘿,支持一下。

    GridView使用集合

    1、自定义多行表头,列合并,行合并 2、删除表身指定列、行 3、固定表头,向下拉动滚动条时,表头固定不动 4、表脚行统计,总计、平均值 二、导入导出 1、导出Excel,Word 2、导入Excel 三、多层嵌套 1、在父...

    第7章 数据绑定控件

    实例212 GridView自动求和及合并多列多行 单元格 336 实例213 GridView合并行或列单元格的5种 通用方式 338 实例214 GridView删除数据时弹出确认对话框 (含内容提示) 340 实例215 GridView数据源为空时显示表头和 ...

    《程序天下:JavaScript实例自学手册》光盘源码

    9.13 单击表头实现表格排序 9.14 单击单元格显示行的详细信息 9.15 表格设置为“100%”时获取表格的宽度 9.16 表格选中后变色 9.17 表格中隐藏下级表格 9.18 表格自动下移 9.19 动态创建固定列数的表格 9.20 动态...

    程序天下:JavaScript实例自学手册

    9.13 单击表头实现表格排序 9.14 单击单元格显示行的详细信息 9.15 表格设置为“100%”时获取表格的宽度 9.16 表格选中后变色 9.17 表格中隐藏下级表格 9.18 表格自动下移 9.19 动态创建固定列数的表格 9.20 动态...

Global site tag (gtag.js) - Google Analytics