备注:这是我辅导的一个项目开发组的一个例子,用文章的方式分享出来,给更多的朋友参考。其实我们这几年的项目中,都不怎么使用服务器控件的形式了,而是更多的采用mvc这种开发模式。但是,如果项目的历史背景是用服务器控件的,也不妨继续沿用,以免变动太大,对项目的整体开发不利。
很多企业业务程序的页面,其实本质上都是对数据的操作,诸如增加、删除、修改和查询(简称:增删改查),如果有可能在一个页面中完整地实现(不需要几个页面转来转去),对于用户来说可能体验较好。
asp.net在2.0中开始提供多种数据控件,并且采用了模板的机制,使得我们上面的需求变得可能。今天要讲的就是号称asp.net中最复杂的控件:gridview的使用。它可以完整实现增删改查。
页面:
代码:
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(); } }}