这段时间老做.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之类的,显然还要多判断一次,所以就成了:
貌似成功了!
等等,不对,怎么第二条纪录没取到数据?测试了半天,不是缓存,然后才多了个心眼,再加一条数据,这样就有四条测试数据了,结果发现偶数行的数据都没绑上,看样子是alternate行的问题了,于是跟踪之,发现偶数行的rowstate是Alternate|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)) ,这样,奇偶行都能生效,当然,其实就是上述第四种思维了。
那么我是怎么更新下拉列表的新值呢?
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 }