分享
 
 
 

在DataGrid控件中编辑数据项

王朝other·作者佚名  2008-05-31
窄屏简体版  字體: |||超大  

要想在DataGrid控件中编辑数据,请使用"按钮列"中的"编辑、更新、取消"列,这些都可以在DataGrid控件的属性生成器中设置

当为DataGrid控件(以控件名为dg1为例)中加入了"编辑、更新、取消"列后,在页面的dg1控件中会多出一列,该列的每一项都是文本为"编辑"的LinkButton/Button。

如果单击了某一行的"编辑"按钮,则该行处于编辑模式,"编辑"按钮被替换为"更新"和"取消"按钮,该行中所有其它的非只读的数据帮定列都会变成TextBox控件格式,以便用户来编辑修改。

当用户修改了非只读的数据帮定列的数据(在TextBox控件中),单击"更新"按钮,将新值保存(一般是保存到数据库中),单击"取消"按钮,该行退出编辑模式。

为了达到单击"编辑"按钮,就转换为行编辑模式的效果,必须编写dg1的EditCommand事件处理方法

为了达到单击"更新"按钮,就保存新值的效果,必须编写dg1的UpdateCommand事件处理方法

为了达到单击"取消"按钮,就退出行编辑模式,必须编辑dg1的CancelCommand事件处理方法

1) dg1.EditCommand事件处理方法-进入行的编辑模式

------------------------------------------------------

private void dg1_EditCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)

{

dg1.EditItemIndex = e.Item.ItemIndex; //设置要编辑的项的索引

binddg1(); //为dg1绑定数据的方法。设置要编辑的项后,要求重新绑定dg1

}

---------------------------------------------------------

2) dg1.CancelCommand事件处理方法-退出行的编辑模式

---------------------------------------------------------

private void dg_CancelCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)

{

dg1.EditItemIndex = e.Item.ItemIndex; //编辑的项的索引为-1,就是不编辑任何项

binddg1(); //重设EditItemIndex后,要求重新绑定dg1

}

---------------------------------------------------------

3) dg1.UpdateCommand事件处理方法-保存更新了的值

要保存更新了的值,首先要重页面中获取这些新值。在事件处理方法中,主要要实现三个功能:

获取更新了的值、更新这些值、退出行更新模式。

一般,DataGrid控件中的显示的数据都是从数据库表中取得的,所以更新了的值也要保存到数据库中,可以用一条update Sql语句或存储过程来执行更新。

要从页面中获取处于编辑模式的行中各列的值,需要一些技巧。以绑定列为例:

获取只读绑定列的值: e.Item.Cells[列索引].Text //只读帮定列处于非编辑状态

获取非只读绑定列的值:((TextBox)(e.Item.Cells[列索引].Controls[0])).Text //处于编辑状态

只读帮定列通常是表中的主键列,其列值要用在update语句的where子句中,一般不更新它们

代码示例:

----------------------------------------------------------

private void DataGrid1_UpdateCommand(object source, System.Web.UI.WebControls.DataGridCommandEventArgs e)

{

//只读绑定列,处于非编辑状态

string customerid = e.Item.Cells[1].Text;

//非只读绑定列,处于编辑状态

string companyname = ((TextBox)(e.Item.Cells[2].Controls[0])).Text;

string city = ((TextBox)(e.Item.Cells[3].Controls[0])).Text;

String strSql = "update customers set companyname = '" + companyname +

"',city = '" + city + "' where customerid = '" + customerid + "'";

executeSql(strSql); //执行update语句,进行更新

DataGrid1.EditItemIndex = -1; //退出行的编辑模式

binddg1();

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有