动态模板列更新数据分页的例子

简介: 前台:     WebForm30                                后台: using System; using System.Collections; using System.
  前台:
<%@ Page language="c#" Codebehind="WebForm30.aspx.cs" AutoEventWireup="false" Inherits="csdn.WebForm30" %>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
<HTML>
 <HEAD>
  <title>WebForm30</title>
  <meta name="GENERATOR" Content="Microsoft Visual Studio .NET 7.1">
  <meta name="CODE_LANGUAGE" Content="C#">
  <meta name="vs_defaultClientScript" content="JavaScript">
  <link href="css.css" rel="stylesheet" type="text/css">
  <meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5">
 </HEAD>
 <body MS_POSITIONING="GridLayout">
  <form id="Form1" method="post" runat="server">
   <asp:DataGrid ID="DataGrid1" Runat="server"></asp:DataGrid>
  </form>
 </body>
</HTML>
后台:
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Data.SqlClient;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;

namespace csdn
{
 /// <summary>
 /// WebForm30
的摘要说明。
 /// </summary>
 public class WebForm30 : System.Web.UI.Page
 {
  protected System.Web.UI.WebControls.DataGrid DataGrid1;
  
  private void Page_Load(object sender, System.EventArgs e)
  {
   //
在此处放置用户代码以初始化页面
   if(!IsPostBack)
   {
    BindGrid();
   }
   CreateDataGrid();//
进行一些DataGrid的设置
  }
 
  protected void CreateDataGrid()
  { 
   DataGrid1.AutoGenerateColumns=false;//
不启用自动生成列
   DataGrid1.CssClass="border";//
边框样式
   DataGrid1.BorderWidth=0;
   DataGrid1.CellSpacing=1;
   DataGrid1.CellPadding=5;
   DataGrid1.ItemStyle.CssClass="item";//
普通列样式
   DataGrid1.HeaderStyle.CssClass="header";//
头样式
   DataGrid1.PagerStyle.CssClass="header";//
页脚样式
   DataGrid1.DataKeyField="stuid";//
主键字段
   DataGrid1.AllowPaging=true;//
允许分页
   DataGrid1.PageSize=5;//
分页大小
   DataGrid1.PagerStyle.Mode=PagerMode.NumericPages;//
数字形式分页
   EditCommandColumn ecc=new EditCommandColumn();//
更新按钮列
   ecc.ButtonType=ButtonColumnType.PushButton;//
下压按钮
   ecc.EditText="
编辑";
   ecc.CancelText="
取消";
   ecc.UpdateText="
更新";//按钮文字
   DataGrid1.Columns.Add(ecc);//
增加按钮列
   DataGrid1.EditCommand+=new DataGridCommandEventHandler(DataGrid1_EditCommand);
   DataGrid1.UpdateCommand+=new DataGridCommandEventHandler(DataGrid1_UpdateCommand);
   DataGrid1.CancelCommand+=new DataGridCommandEventHandler(DataGrid1_CancelCommand);//
更新、取消、编辑事件注册
   DataGrid1.PageIndexChanged += new System.Web.UI.WebControls.DataGridPageChangedEventHandler(DataGrid1_PageIndexChanged);//
分页事件注册,这里需要注意注册事件代码的位置,不能放到BindGrid()
   SetBind();   //
绑定数据
  }

  protected void BindGrid()
  {   
   TemplateColumn tm=new TemplateColumn();
   tm.ItemTemplate=new ColumnTemplate1();//
普通列
   tm.EditItemTemplate=new ColumnTemplate2();//
编辑列
   tm.HeaderText="
姓名";
   DataGrid1.Columns.AddAt(0,tm);//
在第一列增加第一个模板列
   TemplateColumn tm2=new TemplateColumn();
   tm2.ItemTemplate=new ColumnTemplate3();
   tm2.EditItemTemplate=new ColumnTemplate4();
   tm2.HeaderText="
学院";
   DataGrid1.Columns.AddAt(1,tm2);//
在第二列增加第一个模板列
   DataGrid1.ItemDataBound += new System.Web.UI.WebControls.DataGridItemEventHandler(DataGrid1_ItemDataBound);//
数据绑定事件注册,这里需要注意注册事件代码的位置
   SetBind();
  }

  protected void SetBind()
  {
   SqlConnection conn=new SqlConnection(System.Configuration.ConfigurationSettings.AppSettings["conn"]);
   SqlDataAdapter da=new SqlDataAdapter("select * from stu,dep where stu.studepid=dep.depid",conn);
   DataSet ds=new DataSet();
   da.Fill(ds,"table1");
   this.DataGrid1.DataSource=ds.Tables["table1"];
   this.DataGrid1.DataBind();
  
  }

  private void DataGrid1_ItemDataBound(object sender, System.Web.UI.WebControls.DataGridItemEventArgs e)
  {
   SqlConnection conn=new SqlConnection(System.Configuration.ConfigurationSettings.AppSettings["conn"]);
   SqlDataAdapter da=new SqlDataAdapter("select * from dep",conn);
   DataSet ds=new DataSet();
   da.Fill(ds,"table1");
   if(e.Item.ItemType==ListItemType.EditItem)
   {
    DropDownList ddl=(DropDownList)e.Item.FindControl("dep");
    ddl.DataSource=ds.Tables["table1"];
    ddl.DataTextField="depname";
    ddl.DataValueField="depid";
    ddl.DataBind();
    ddl.Items.FindByValue(Convert.ToString(DataBinder.Eval(e.Item.DataItem,"depid"))).Selected=true;
   }
  }

  private void DataGrid1_EditCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)
  {
   this.DataGrid1.EditItemIndex=e.Item.ItemIndex;
   BindGrid();
  }

  private void DataGrid1_CancelCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)
  {
   this.DataGrid1.EditItemIndex=-1;
   BindGrid();
  }

  private void DataGrid1_UpdateCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)
  {
   string uid=e.Item.UniqueID+":";//
注意别遗漏冒号
   SqlConnection conn=new SqlConnection(System.Configuration.ConfigurationSettings.AppSettings["conn"]);
   SqlCommand comm=new SqlCommand("update stu set stuname=@name,studepid=@depid where stuid=@id",conn);
   SqlParameter parm1=new SqlParameter("@name",SqlDbType.NVarChar,50);
   parm1.Value=Request.Form[uid+"name"].ToString();
   SqlParameter parm2=new SqlParameter("@depid",SqlDbType.Int);
   parm2.Value=Request.Form[uid+"dep"].ToString();;
   SqlParameter parm3=new SqlParameter("@id",SqlDbType.Int);
   parm3.Value=this.DataGrid1.DataKeys[e.Item.ItemIndex];
   comm.Parameters.Add(parm1);
   comm.Parameters.Add(parm2);
   comm.Parameters.Add(parm3);
   conn.Open();
   comm.ExecuteNonQuery();
   conn.Close();
   this.DataGrid1.EditItemIndex=-1;
   BindGrid();   
//
之所以不能采用以前的((TextBox)e.Item.FindControl("name")).Text来取得数据时因为,DataGrid列是动态添加的,根本取不到
  }

  private void DataGrid1_PageIndexChanged(object source, System.Web.UI.WebControls.DataGridPageChangedEventArgs e)
  {
   this.DataGrid1.CurrentPageIndex=e.NewPageIndex;
   BindGrid();
  }

  #region Web 窗体设计器生成的代码
  override protected void OnInit(EventArgs e)
  {
   //
   // CODEGEN:
该调用是 ASP.NET Web 窗体设计器所必需的。
   //
   InitializeComponent();
   base.OnInit(e);
  }
 
  /// <summary>
  ///
设计器支持所需的方法 - 不要使用代码编辑器修改
  ///
此方法的内容。
  /// </summary>
  private void InitializeComponent()
  {   
   this.Load += new System.EventHandler(this.Page_Load);

  }
  #endregion
 }

 public class ColumnTemplate1 : ITemplate
 {
  
  public void InstantiateIn(Control container)      
  {
   LiteralControl l = new LiteralControl();
   l.DataBinding += new EventHandler(this.OnDataBinding);
   container.Controls.Add(l);   
  }

  public void OnDataBinding(object sender, EventArgs e)
  {
   LiteralControl l = (LiteralControl) sender;
   DataGridItem container = (DataGridItem) l.NamingContainer;
   l.Text = ((DataRowView)container.DataItem)["stuname"].ToString();
  }
 }

 public class ColumnTemplate2 : ITemplate
 {
  public void InstantiateIn(Control container)      
  {
   TextBox t = new TextBox();
   t.Width=88;
   t.ID="name";//
需要给一个id,在Request.Form的时候可以取
   t.DataBinding += new EventHandler(this.OnDataBinding);
   container.Controls.Add(t);   
  }

  public void OnDataBinding(object sender, EventArgs e)
  {
   TextBox t= (TextBox) sender;
   DataGridItem container = (DataGridItem) t.NamingContainer;
   t.Text = ((DataRowView)container.DataItem)["stuname"].ToString();//
绑定stuname字段
  }
 }

 public class ColumnTemplate3 : ITemplate
 {
  public void InstantiateIn(Control container)      
  {
   LiteralControl l = new LiteralControl();
   l.DataBinding += new EventHandler(this.OnDataBinding);
   container.Controls.Add(l);   
  }

  public void OnDataBinding(object sender, EventArgs e)
  {
   LiteralControl l = (LiteralControl) sender;
   DataGridItem container = (DataGridItem) l.NamingContainer;
   l.Text = ((DataRowView)container.DataItem)["depname"].ToString();
  }
 }

 public class ColumnTemplate4 : ITemplate
 {
  public void InstantiateIn(Control container)      
  {
   DropDownList dpl = new DropDownList();
   dpl.ID="dep";
   container.Controls.Add(dpl);   
  }//
这里没有为这个下拉框进行数据绑定,在DataGrid1ItemDataBound中进行了这个操作
 }
}

代码比较简单,在代码中有注释简单的解释。
补充2点:(1)这次的DataGrid是在设计生成的,不是上次的运行时,后者会造成更新的紊乱;(2)处于简单,代码中模板列类没有很好的封装,在运用的时候还是应该对字段和模板列类型(ListItemType)进行封装

 

目录
相关文章
|
6月前
|
小程序 JavaScript
小程序简单循环列表数据渲染实例
小程序简单循环列表数据渲染实例
40 0
|
JavaScript
VUE之vxe-table高级表格(表格内增删改、导入、导出、自定义打印、列设置隐藏显示等)用法
VUE之vxe-table高级表格(表格内增删改、导入、导出、自定义打印、列设置隐藏显示等)用法
6530 0
VUE之vxe-table高级表格(表格内增删改、导入、导出、自定义打印、列设置隐藏显示等)用法
|
1月前
|
JavaScript 前端开发
【vue】设计一个表格,增删改查,分页,固定列,特殊字符校验
【vue】设计一个表格,增删改查,分页,固定列,特殊字符校验
15 0
【vue】设计一个表格,增删改查,分页,固定列,特殊字符校验
|
2月前
|
JSON 开发框架 前端开发
利用bootstraptable展示数据,对数据进行排序分页等操作
利用bootstraptable展示数据,对数据进行排序分页等操作
15 0
|
7月前
|
存储 关系型数据库 MySQL
视图与索引的详细用法
视图与索引的详细用法
41 0
|
JSON JavaScript 前端开发
VUE element-ui之table表格前端自动过滤(筛选),不调用数据接口筛选表格,方法
VUE element-ui之table表格前端自动过滤(筛选),不调用数据接口筛选表格,方法
589 0
VUE element-ui之table表格前端自动过滤(筛选),不调用数据接口筛选表格,方法
|
SQL
【自然框架】表单控件 之 一个表单修改多个表里的记录
      FormView 确实挺方便的,不过他也有几个小问题,只把FormView拖到页面里是不行的,还得再拽几个文本框、下拉列表框这一类的控件,还得布局。然后还要弄一个DataSource的控件,利用这个控件把文本框等控件和字段对应上,DataSource也有一个致命的缺点,默认情况下,他是把SQL语句以属性的形式放在了.aspx页面里面。
884 0
基类、接口的应用——表单控件:一次添加、修改一条记录,一次修改多条记录。(上)
好久没发帖子了,又加了不少的功能呀。(图片仅是测试,不代表什么表情。) 本来我也想写一个2007的总结的,但是看到很多人都写了,我就不凑热闹了,写点和代码有关系的吧。 写作原因: 1、在项目里做得最多的操作恐怕就是保存数据了,总是要写一大堆的代码,能不能简单一点呢?2005来了,似乎可以减少一些代码,但是03里怎么办呢? 2、基类、接口、策略模式,好多高手都讨论过了,但是都是理论上的,在实践中如何应用呢?在webform 里面又怎么使用呢? 目的: 1、做一个“控件”来应对各种表单的录入,包括一次保存一条记录、一次保存多条记录。
988 0
|
BI 图形学
C#.NET自定义报表数据打印
原文:C#.NET自定义报表数据打印      这是一个自定义的报表打印,是对PrintPreviewDialog的扩展和封装。PrintPreviewDialog是一个windows的打印预览控件,该类返回的就是一个PrintPreviewDialog对象了,直接显示该控件就可以了。
865 0
select标签动态获取数据时如何控制下拉框长度
队列ID panelHeight="100" 设置下拉框的长度,panelHeight="auto"为自动匹配大小。
2514 0