ExtractValuesFromCell 方法使用:而该方法也被很多种列类型所支持
DataControlField, BoundField, AutoGeneratedField, CheckBoxField, ImageField, TemplateField, DynamicField,你可以在 GridView 的 RowUpdating, RowDeleting 等事件中使用它。利用该方法,可以将值提取到所需的字典里去,然后再从字典中读取。这些字典包括:e.Keys, e.NewValues, e.OldValues 等。
代码如下:
Code
GridViewRow row =this.GridView1.Rows[e.RowIndex];
//primary key
this.GridView1.Columns[0].ExtractValuesFromCell(e.Keys, row.Cells[0] as DataControlFieldCell, DataControlRowState.Edit, true);
//Update columns
this.GridView1.Columns[1].ExtractValuesFromCell(e.NewValues, row.Cells[1] as DataControlFieldCell, DataControlRowState.Edit, true);
//get primary key
string id = e.Keys["userName"].ToString();
//get Update columns
string userTel = e.NewValues["userTel"].ToString();
// 执行相关的数据库更新操作
using (SqlConnection con = new SqlConnection(ConfigurationManager.ConnectionStrings["con"].ConnectionString))
{
con.Open();
using (SqlCommand com = new SqlCommand("update users set userTel='"+userTel+"' where userName='"+id+"'", con))
{
com.ExecuteNonQuery();
}
}
这样,在大多数场合我们可以尽可能多的使用 BoundField,并且也能正确读取到其编辑时的值,省下自定义 TemplateField 的一堆代码了。