博客园  :: 首页  :: 联系 :: 订阅 订阅  :: 管理

DataGrid使用技巧小总结-个性化分页及复杂表头

Posted on 2006-04-23 13:31  ╁蓝驿┲→  阅读(139)  评论(0编辑  收藏  举报
 DataGrid使用技巧小总结-个性化分页及复杂表头   [ 日期:2006-02-22 ]   [ 来自: ]


    在使用DataGrid 的时候,总是会有各种各样的需求,在和数据库打交道的项目中用的最多的恐怕就属DataGrid 了吧,微软有时候做的就差那么一点点,所以就需要我们自己来动手实现啦.


DataGrid 自定义分页导航 


无需任何其他第三方控件,在DataGrid 自己分页的基础上再个性化一点.
效果:  


让DataGrid自己的分页实现这样的效果
[1][2][3][4][5][6]    


让DataGrid自己的分页实现这样的效果
[1][2][3][4][5][6] 


private void grid_ItemCreated(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
  {
   if(e.Item.ItemType==ListItemType.Pager)
   {    
    foreach (Control c in e.Item.Cells[0].Controls)
    {
     if (c is Label)  //当前页数
     {
        Label lblpage=(Label)c;
//      lblpage.ForeColor= System.Drawing.ColorTranslator.FromHtml("#e78a29"); //#e78a29 ,#FF0000     
//      lblpage.Font.Bold=true;
        lblpage.Text="[<font color=#e78a29><b>"+lblpage.Text+"</b></font>]";     
      //((Label)c).ForeColor = System.Drawing.Color.Green;      
//      break;
     }
     if(c is LinkButton) //链接的其他页数
     {      
         LinkButton linkButton = (LinkButton)c;       
         linkButton.Text = "[" + linkButton.Text+"]"; 
     }
    }    
   }
  }  


DataGrid等控件中的自动编号: 


添加一个模版列: 


<asp:TemplateColumn HeaderText="No.">
    <ItemStyle HorizontalAlign="Center"></ItemStyle>
    <ItemTemplate>
        <asp:Label runat="server" Text='<%# dgCustomize.CurrentPageIndex*dgCustomize.PageSize+dgCustomize.Items.Count+1 %>'>
        </asp:Label>
    </ItemTemplate>
</asp:TemplateColumn> 

另一种简单的方式
<asp:TemplateColumn HeaderText="序号">
<ItemTemplate>
<%# Container.ItemIndex + 1%>
</ItemTemplate>
</asp:TemplateColumn>