当前位置:Gxlcms > html代码 > 一个在ASP.NET中利用服务器控件GridView实现数据增删改查的例子_html/css_WEB-ITnose

一个在ASP.NET中利用服务器控件GridView实现数据增删改查的例子_html/css_WEB-ITnose

时间:2021-07-01 10:21:17 帮助过:33人阅读

备注:这是我辅导的一个项目开发组的一个例子,用文章的方式分享出来,给更多的朋友参考。其实我们这几年的项目中,都不怎么使用服务器控件的形式了,而是更多的采用MVC这种开发模式。但是,如果项目的历史背景是用服务器控件的,也不妨继续沿用,以免变动太大,对项目的整体开发不利。

很多企业业务程序的页面,其实本质上都是对数据的操作,诸如增加、删除、修改和查询(简称:增删改查),如果有可能在一个页面中完整地实现(不需要几个页面转来转去),对于用户来说可能体验较好。

ASP.NET在2.0中开始提供多种数据控件,并且采用了模板的机制,使得我们上面的需求变得可能。今天要讲的就是号称ASP.NET中最复杂的控件:GridView的使用。它可以完整实现增删改查。

页面:

<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="WebApplicationSample.Default" %>                

代码:

using System;using System.Collections.Generic;using System.Web.UI.WebControls;namespace WebApplicationSample{    ///     /// 这个实例主要演示了如何使用GridView进行数据的增、删、改、查。    /// 更多有关于该控件的知识,可以参考 http://msdn.microsoft.com/zh-cn/library/vstudio/system.web.ui.webcontrols.gridview.aspx (请仔细阅读)    ///     public partial class Default : System.Web.UI.Page    {        ///         /// 这是我们定义的一个业务实体类,用来保存界面上的列表数据,为了保存,必须支持序列化        ///         [Serializable]        public class Employee        {            public string FirstName { get; set; }            public string LastName { get; set; }        }        private List data = new List();//这是用来保存那个列表数据的字段        ///         /// 重写这个方法来保存视图状态。因为每次页面刷新的时候,默认情况下,data都会被清空,如果希望在多次回发的过程中保存数据,则重写该方法        ///         ///         protected override object SaveViewState()        {            var obj = new object[] { base.SaveViewState(), data };            return obj;        }        ///         /// 重写该方法,是与上面这个方法配套,在回发回来之后加载并还原        ///         ///         protected override void LoadViewState(object savedState)        {            var obj = savedState as object[];            base.LoadViewState(obj[0]);            data = obj[1] as List;        }        ///         /// 页面初始化的时候执行该代码        ///         ///         ///         protected void Page_Load(object sender, EventArgs e)        {            if (!IsPostBack)            {//这里只是一个示例,默认给页面添加一个初始的员工,实际在做的时候,可以不加                data = new List(){                    new Employee(){FirstName ="ares",LastName ="chen"}                };                gvData.DataSource = data;                gvData.DataBind();            }        }        ///         /// 添加新的员工时执行该代码        ///         ///         ///         protected void btAddNew_Click(object sender, EventArgs e)        {            data.Add(new Employee());//创建一个空的对象            gvData.DataSource = data;//设置数据源            gvData.EditIndex = data.Count - 1;//设置当前这个对象为编辑状态            gvData.DataBind();//绑定数据        }        ///         /// 当用户决定要删除某一行数据时执行该代码        ///         ///         ///         protected void gvData_RowDeleting(object sender, GridViewDeleteEventArgs e)        {            //删除某一行            data.RemoveAt(e.RowIndex);            gvData.DataSource = data;            gvData.EditIndex = -1;            gvData.DataBind();        }        ///         /// 当用户要保存修改时执行该代码        ///         ///         ///         protected void gvData_RowUpdating(object sender, GridViewUpdateEventArgs e)        {            var index = e.RowIndex;//获取当前编辑行当索引号            var row = gvData.Rows[index];//获取当前用户编辑的这一行            var firstName = (row.Cells[1].Controls[0] as TextBox).Text;//获取用户输入的数据            var lastName = (row.Cells[2].Controls[0] as TextBox).Text;//获取用户输入的数据            var emp = data[index];//找到这个对象            emp.FirstName = firstName;            emp.LastName = lastName;            gvData.DataSource = data;            gvData.EditIndex = -1;//退出编辑状态            gvData.DataBind();        }        ///         /// 当用户要取消编辑的时候        ///         ///         ///         protected void gvData_RowCancelingEdit(object sender, GridViewCancelEditEventArgs e)        {            gvData.DataSource = data;            gvData.EditIndex = -1;            gvData.DataBind();        }        ///         /// 当用户要进行编辑的时候        ///         ///         ///         protected void gvData_RowEditing(object sender, GridViewEditEventArgs e)        {            gvData.DataSource = data;            gvData.EditIndex = e.NewEditIndex;            gvData.DataBind();        }    }}

人气教程排行