您的位置:首页精文荟萃软件资讯 → 如何给DataGrid添加双题头分类显示

如何给DataGrid添加双题头分类显示

时间:2004/10/7 18:28:00来源:本站整理作者:蓝点我要评论(0)

问题出来了,这个查询通常情况下应该在DataGrid的上面也就是查询结果的上面,我要怎么才能保留原来的题头同时再添加一个题头呢(双题头)?     问题出来了,改如何解决呢?想了好多办法都不行,如果要将Header重画,那么还要处理排序是前后台的交互问题,那么只能再保留原来Header不动的基础上添加新的Header。无意中发现在分页的时候可以有几种分页显示的方法,在分页面板里面有一个选现可以选择分页的位置,可以选择上下型,在选择这个类型的时候DataGrid在原来的Header上面又多了一行,我们今天就利用这一行来完成我们的任务,今天我们不产生查询的UI而是产生一个分类的题头,我们使用测试数据库Northwind中的Employees来显示数据,首先我们要做的是绑定数据绑定代码如下:   SqlConnection con = new SqlConnection("server=localhost;database=Northwind;uid=sa;pwd=;");
        SqlDataAdapter da = new SqlDataAdapter("SELECT LastName+' '+FirstName as name, BirthDate, Country, Title, HireDate FROM Employees",con);
        DataTable dt = new DataTable();
        da.Fill(dt);
        this.DataGrid1.DataSource = dt;
        this.DataGrid1.DataBind();
 }     接着我们在ItemCreated里面添加适当的代码来完成我们的任务,在PowerDataGrid该事件处理函数里面已经添加了创建一个自定义分页的UI!如果你在PowerDataGrid里面添加需要判断两个(上下)Pager的位置,我们可以使用一个全局变量来判断。     定义一个全局变量 private int m_CreatePageTimes = 0;
   然后我们为该事件处理函数添加如下代码:  private int m_CreatePageTimes  = 0;
 private void DataGrid1_ItemCreated(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e) {
        ListItemType elemType = e.Item.ItemType;
        if (elemType == ListItemType.Pager) {
           if (m_CreatePageTimes == 0) {
              TableCell cellPerson = (TableCell) e.Item.Controls[0];
              cellPerson.Controls.Clear();cellPerson.BackColor = Color.Navy;
              cellPerson.ForeColor = Color.Yellow;
              cellPerson.ColumnSpan = 3;
              cellPerson.HorizontalAlign = HorizontalAlign.Center;
              cellPerson.Controls.Add(new LiteralControl("个人信息"));
 
              TableCell cellJob = new TableCell();
              cellJob.BackColor = Color.Navy;
              cellJob.ForeColor = Color.Yellow;
              cellJob.ColumnSpan = 2;
              cellJob.HorizontalAlign = HorizontalAlign.Center;
              cellJob.Controls.Add(new LiteralControl("工作信息"));
              e.Item.Controls.Add(cellJob);
              m_CreatePageTimes  ++;
           }else if(m_CreatePageTimes ==1){
              // create custom pager UI
           }
        }     最后是DataGrid的HTML部分的代码如下:
 <asp:DataGrid id="DataGrid1" runat="server" AllowPaging="True" AutoGenerateColumns="False" Width="100%"
    PageSize="2">
    <Columns>
     <asp:BoundColumn DataField="name" HeaderText="姓名"></asp:BoundColumn>
     <asp:BoundColumn DataField="BirthDate" HeaderText="生日"></asp:BoundColumn>
     <asp:BoundColumn DataField="Country" HeaderText="国家"></asp:BoundColumn>
     <asp:BoundColumn DataField="Title" HeaderText="头衔"></asp:BoundColumn>
     <asp:BoundColumn DataField="HireDate" HeaderText="雇佣日期"></asp:BoundColumn>
    </Columns>
    <PagerStyle Position="TopAndBottom" Mode="NumericPages"></PagerStyle>
   </asp:DataGrid>

 运行效果如下所示:

相关阅读 Windows错误代码大全 Windows错误代码查询激活windows有什么用Mac QQ和Windows QQ聊天记录怎么合并 Mac QQ和Windows QQ聊天记录Windows 10自动更新怎么关闭 如何关闭Windows 10自动更新windows 10 rs4快速预览版17017下载错误问题Win10秋季创意者更新16291更新了什么 win10 16291更新内容windows10秋季创意者更新时间 windows10秋季创意者更新内容kb3150513补丁更新了什么 Windows 10补丁kb3150513是什么

文章评论
发表评论

热门文章 360快剪辑怎么使用 36金山词霸如何屏幕取词百度收购PPS已敲定!3

最新文章 微信3.6.0测试版更新了微信支付漏洞会造成哪 360快剪辑怎么使用 360快剪辑软件使用方法介酷骑单车是什么 酷骑单车有什么用Apple pay与支付宝有什么区别 Apple pay与贝贝特卖是正品吗 贝贝特卖网可靠吗

人气排行 xp系统停止服务怎么办?xp系统升级win7系统方电脑闹钟怎么设置 win7电脑闹钟怎么设置office2013安装教程图解:手把手教你安装与qq影音闪退怎么办 QQ影音闪退解决方法VeryCD镜像网站逐个数,电驴资料库全集同步推是什么?同步推使用方法介绍QQ2012什么时候出 最新版下载EDiary——一款好用的电子日记本