首页 | 互联网 | 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 >> 正文

ASP.NET 2.0中动态添加GridView

     动态添加列,关键是实现 ITemplate.InstantiateIn 方法。下面是一个添加 GridView 模板列的例子。
  
  <%@ Page Language="C#" %>
  <%@ Import Namespace="System.Data" %>
  <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
   "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  
  <script runat="server">
   ICollection CreateDataSource()
   {
   DataTable dt = new DataTable();
   DataRow dr;
   dt.Columns.Add(new DataColumn("id", typeof(Int32)));
   dt.Columns.Add(new DataColumn("text", typeof(string)));
   for (int i = 0; i < 6; i++)
   {
   dr = dt.NewRow();
   dr[0] = i;
   dr[1] = "列表项目 " + i.ToString();
   dt.Rows.Add(dr);
   }
   DataView dv = new DataView(dt);
   return dv;
   }
  
   public class GridViewTemplate : ITemplate
   {
   private DataControlRowType templateType;
   private string columnName;
  
   public GridViewTemplate( DataControlRowType type, string colname )
   {
   templateType = type;
   columnName = colname;
   }
  
   public void InstantiateIn( System.Web.UI.Control container )
   {
   switch (templateType)
   {
   case DataControlRowType.Header:
   Literal lc = new Literal();
   lc.Text = columnName;
   container.Controls.Add(lc);
   break;
   case DataControlRowType.DataRow:
   DropDownList drr = new DropDownList();
   drr.ID = "dropdown";
   drr.AppendDataBoundItems = true;
   drr.Items.Add(new ListItem("-----请选择------",""));
   drr.Items.Add(new ListItem("AA", "a"));
   drr.Items.Add(new ListItem("BB", "b"));
   drr.Items.Add(new ListItem("CC", "c"));
   container.Controls.Add(drr);
   break;
   default:
   break;
   }
   }
   }
  
   protected void Page_Load(object sender, EventArgs e)
   {
   if (!IsPostBack)
   {
   TemplateField customField = new TemplateField();
   customField.ShowHeader = true;
   customField.HeaderTemplate = new GridViewTemplate(DataControlRowType.Header, "动态添加列");
   customField.ItemTemplate = new GridViewTemplate(DataControlRowType.DataRow, "");
   GridView1.Columns.Add(customField);
   GridView1.DataSource = CreateDataSource();
   GridView1.DataBind();
   }
   }
  
   protected void GridView1_RowDataBound( object sender, GridViewRowEventArgs e )
   {
   if (e.Row.RowType == DataControlRowType.DataRow)
   {
   //可以在这里访问数据库的其它字段的值,可以设置默认选择项,具体应用,看自己的发挥了。
   //下面只是例子,举一反三,不再费话了
   DataRowView gv = (DataRowView)e.Row.DataItem;
   int itemSeleted = Int32.Parse(gv.Row["id"].ToString()) > 3 ? 0 : Int32.Parse(gv.Row["id"].ToString());
   DropDownList dr = (DropDownList)e.Row.FindControl("dropdown");
   dr.SelectedIndex = itemSeleted;
   }
   }
  </script>
  
  <html xmlns="http://www.w3.org/1999/xhtml">
  <head id="Head1" runat="server">
   <title>GridView动态添加模板列的例子</title>
  </head>
  <body>
  <form id="form1" runat="server">
   <asp:GridView ID="GridView1" runat="server" AutoGenerateColumns="False"
   OnRowDataBound="GridView1_RowDataBound">
   <Columns>
   <asp:BoundField HeaderText="标题" DataField="text"/>
   </Columns>
   </asp:GridView>
  </form>
  </body>
  </html>
【责编:Peng】

中国IT教育

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

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