首页 | 互联网 | IT动态 | IT培训 | Cisco | Windows | Linux | Java | .Net | Oracle | 软件测试 | C/C++ | 嵌入式开发 | 存储世界 | 服务器
网络设备 | IDC | 安全 | 求职招聘 | 数字网校 | 笔记本电脑 | 北大青鸟 | 技术专题 | 电子书下载 | 教学视频 | 源码下载 | 搜索 | 博客 | 论坛
中国IT实验室Dotnet频道
中国IT教育
Google
首页 ASP.NET  C#  XML/WebService ADO.NET VC.NET VB.NET .NET 资讯动态 专题 RSS订阅 讨论 下载
您现在的位置: 中国IT实验室 >> Dotnet >> ASP.NET >> 正文

自动填充固定行数的 GridView

    在有些开发实践中,有时候为了页面美观的需要,需要将GridView填充成固定行数的表格,下面这个方法实现了这种填充的功能。此方法可以处理自动产生列和模版列。注意:由于时间关系,没有实现对完全空白数据的填充,呵呵,如果需要,可以自己添加哈:)! 

C#

<%@ Page Language="C#"%>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"
>

<script runat="server">
  
// 计算数据,完全可以从数据看取得
  ICollection CreateDataSourceByXianhuiMeng()
  {
    System.Data.DataTable dt 
= new System.Data.DataTable();
    System.Data.DataRow dr;
    dt.Columns.Add(
new System.Data.DataColumn("学生班级"typeof(System.String)));
    dt.Columns.Add(
new System.Data.DataColumn("学生姓名"typeof(System.String)));
    dt.Columns.Add(
new System.Data.DataColumn("语文"typeof(System.Decimal)));
    dt.Columns.Add(
new System.Data.DataColumn("数学"typeof(System.Decimal)));
    dt.Columns.Add(
new System.Data.DataColumn("英语"typeof(System.Decimal)));
    dt.Columns.Add(
new System.Data.DataColumn("计算机"typeof(System.Decimal)));

    
for (int i = 0; i < 8; i++)
    {
      System.Random rd 
= new System.Random(Environment.TickCount * i); ;
      dr 
= dt.NewRow();
      dr[
0= "班级" + i.ToString();
      dr[
1= "【孟子E章】" + i.ToString();
      dr[
2= System.Math.Round(rd.NextDouble() * 1002);
      dr[
3= System.Math.Round(rd.NextDouble() * 1002);
      dr[
4= System.Math.Round(rd.NextDouble() * 1002);
      dr[
5= System.Math.Round(rd.NextDouble() * 1002);
      dt.Rows.Add(dr);
    }
    System.Data.DataView dv 
= new System.Data.DataView(dt);
    
return dv;
  }

  
// 设置每页显示的行数  
  int TotalRowCount = 12;
  
// 自动填充的行数
  int numCount = 0;
  protected 
void Page_Load(object sender, EventArgs e)
  {
    
if (!Page.IsPostBack)
    {
      GridView1.DataSource 
= CreateDataSourceByXianhuiMeng();
      GridView1.DataBind();
    }
  }

  protected 
void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
  {
    
if (e.Row.RowType == DataControlRowType.DataRow)
    {
      
// 计算自动填充的行数
      numCount++;
    }
    
if (e.Row.RowType == DataControlRowType.Footer)
    {
      
// 计算完毕,在此添加缺少的行
      int toLeft = TotalRowCount - numCount;
      
int numCols = GridView1.Rows[0].Cells.Count;

      
for (int i = 0; i < toLeft; i++)
      {
        GridViewRow row 
= new GridViewRow(-1-1, DataControlRowType.EmptyDataRow, DataControlRowState.Normal);
        
for (int j = 0; j < numCols; j++)
        {
          TableCell cell 
= new TableCell();
          cell.Text 
= "&nbsp;";
          row.Cells.Add(cell);
        }
        GridView1.Controls[
0].Controls.AddAt(numCount + 1 + i, row);
      }
    }
  } 
</script>

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
  
<title>自动填充固定行数的 GridView</title>
</head>
<body>
  
<form id="form1" runat="server">
    
<asp:GridView ID="GridView1" runat="server" OnRowDataBound="GridView1_RowDataBound"
      Font-Size
="12px" CellPadding="3">
      
<HeaderStyle BackColor="#EDEDED" />
      
<Columns>
        
<asp:TemplateField HeaderText="模版列">
          
<ItemTemplate>
            
<%#Eval("学生姓名"%>
          
</ItemTemplate>
        
</asp:TemplateField>
      
</Columns>
    
</asp:GridView>
  
</form>
</body>
</html>
【责编:Peng】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·开源软件测试工具学习专题
 ·JSP Web开发 入门基础到高手进阶教程…
 ·JavaFX—是Java桌面的新希望么?
 ·安全至上 .NET开发安全策略…
 ·测试用例设计之道-测试用例学习专题
 ·面向Java开发人员的Scala指南
 ·Java设计模式之实例详解
 ·Oracle数据库11g 面向DBA和开发人员的重要新特性…
 ·桌面应用软件编程 J2SE技术详解…
 ·我“炫”我精彩-------WPF开发教程
 今日更新
 社区讨论
 博客论点
 频道精选
 Dotnet频道相关导航