GridView行编辑中找DropDownList控件

 这段时间老做.net项目,所以笔记全是asp.net的,呵呵,还是gridview,一些简单的数据我就在行内编辑了,一些简单的几选一的数据通常绑掉一个下拉列表,显示的时候是文字,编辑的时候是下拉列表,同时还要选定在对应的值上,这样,很多人就碰到了这样一个问题:当commandName="Edit“的事件执行后,如何给编辑模板里面的下拉列表绑数据呢?

当然,在前台指定dataSource,TextField和ValueFiled显然可以解决,但是还是不能把选项指定在对应的值上,所以,还是到后台用代码找到这个控件,然后给seletedValue赋值。

 

最初我是响应的onRowEditing方法,可是参数里只有一个当前行,而且gridview.rows[index].findcontrol(id) as dropdownlist也找不到控件,折腾了好久,才想起,与其编辑前绑数据,不如在初始化gridview的时候绑数据,于是就在onRowDataBounding的时候来绑数据,并特别注意了一个e.Row.RowType == DataControlRowType.DataRow

这时候e.Row.FindControl(id)是能找到了,可是啼笑皆非地发现一个数据也没绑上,幸亏发现了还有一个叫RowState的属性,里面有edit,insert之类的,显然还要多判断一次,所以就成了:

if (e.Row.RowType == DataControlRowType.DataRow && e.Row.RowState == DataControlRowState.Edit)

 貌似成功了!

等等,不对,怎么第二条纪录没取到数据?测试了半天,不是缓存,然后才多了个心眼,再加一条数据,这样就有四条测试数据了,结果发现偶数行的数据都没绑上,看样子是alternate行的问题了,于是跟踪之,发现偶数行的rowstate是Alternate|Edit,晕,与是我写成e.Row.RowState == (DataControlRowState.Alternate | DataControlRowState.Edit),测试成功,当然很麻烦,这样奇数行又失败了,得再判断一次。

假如只判断偶数行的话,方法有这么多:

代码
e.Row.RowState == (DataControlRowState.Alternate|DataControlRowState.Edit)

((
int)e.Row.RowState)==5//转换为整数

if (e.Row.RowState==DataControlRowState.Edit || e.Row.RowState.ToString().Equals("Alternate, Edit"))//转为字符串

if ((e.Row.RowState & DataControlRowState.Edit) != 0)//枚举的位运算

在一个老外简洁有力的答复中,我用了if (e.Row.RowType == DataControlRowType.DataRow && ((e.Row.RowState & DataControlRowState.Edit) > 0)) ,这样,奇偶行都能生效,当然,其实就是上述第四种思维了。

 那么我是怎么更新下拉列表的新值呢?

代码
1
2 protected void update_status(object sender, GridViewUpdateEventArgs e)
3 {
4 int index = gridList.EditIndex;
5 e.NewValues["status"] = (gridList.Rows[index].FindControl("ddlstatus") as DropDownList).Text;
6 ods.UpdateParameters["id"].DefaultValue = e.Keys["id"].ToString();
7 ods.UpdateParameters["status"].DefaultValue = e.NewValues["status"].ToString();
8 ods.Update();
9 gridList.DataSourceID = "ods";
10 gridList.DataBind();
11 Response.Redirect("Finace.aspx");
12 e.Cancel = true;
13 }
我有四列数据,看第5行和第7行,显然我只给newvalues字典的一个键赋了值,其它值也就是自动生成的编辑项(文本框),可以直接取用,模板里的下拉列表取不到值,所以就需要人为把下拉列表的值更新到字典里,当然,你也可以直接更新给数据源的参数,呵呵

posted @ 2010-05-01 04:28  $walker  阅读(1206)  评论(0编辑  收藏  举报