还在使用这样的代码吗?
其实这些工作(在单元格中查找控件,并尝试获取其中的值)已经被封装了。现在,只要调用 ExtractValuesFromCell 方法即可。
而该方法也被很多种列类型所支持:
DataControlField, BoundField, AutoGeneratedField, CheckBoxField, ImageField, TemplateField, DynamicField
你可以在 GridView 的 RowUpdating, RowDeleting 等事件中使用它。利用该方法,可以将值提取到所需的字典里去,然后再从字典中读取。这些字典包括:e.Keys, e.NewValues, e.OldValues 等。
一小段例子代码:
这样,在大多数场合我们可以尽可能多的使用 BoundField,并且也能正确读取到其编辑时的值,省下自定义 TemplateField 的一堆代码了。
vartxtName=grid1.Rows[e.RowIndex].Cells[0].FindControl("txtName")asTextBox;
if(txtName!=null)
{
//读取值
//
}
if(txtName!=null)
{
//读取值
//

}
其实这些工作(在单元格中查找控件,并尝试获取其中的值)已经被封装了。现在,只要调用 ExtractValuesFromCell 方法即可。
而该方法也被很多种列类型所支持:
DataControlField, BoundField, AutoGeneratedField, CheckBoxField, ImageField, TemplateField, DynamicField
你可以在 GridView 的 RowUpdating, RowDeleting 等事件中使用它。利用该方法,可以将值提取到所需的字典里去,然后再从字典中读取。这些字典包括:e.Keys, e.NewValues, e.OldValues 等。
一小段例子代码:
//更新
protectedvoidgrid1_RowUpdating(objectsender,GridViewUpdateEventArgse)
{
varrow=grid1.Rows[e.RowIndex];
//提取Id字段的值
grid1.Columns[0].ExtractValuesFromCell(
e.Keys,
row.Cells[0]asDataControlFieldCell,
DataControlRowState.Edit,
true/*includereadonly*/);
//提取Name字段的值
grid1.Columns[1].ExtractValuesFromCell(
e.NewValues,
row.Cells[1]asDataControlFieldCell,
DataControlRowState.Edit,
true/*includereadonly*/);
varid=int.Parse(e.Keys["id"].ToString());
varname=(string)e.NewValues["name"];
//执行相关的数据库更新操作
//
}
protectedvoidgrid1_RowUpdating(objectsender,GridViewUpdateEventArgse)
{
varrow=grid1.Rows[e.RowIndex];
//提取Id字段的值
grid1.Columns[0].ExtractValuesFromCell(
e.Keys,
row.Cells[0]asDataControlFieldCell,
DataControlRowState.Edit,
true/*includereadonly*/);
//提取Name字段的值
grid1.Columns[1].ExtractValuesFromCell(
e.NewValues,
row.Cells[1]asDataControlFieldCell,
DataControlRowState.Edit,
true/*includereadonly*/);
varid=int.Parse(e.Keys["id"].ToString());
varname=(string)e.NewValues["name"];
//执行相关的数据库更新操作
//

}
这样,在大多数场合我们可以尽可能多的使用 BoundField,并且也能正确读取到其编辑时的值,省下自定义 TemplateField 的一堆代码了。