DataKeyNames,DataKeys 用法浅谈(二)

DataKeyNames作为GridView中的一个属性,我们可以利用这个属性结合DataKeys方便的访问GridView中每个字段的值。

先说怎么用

DataKeyNames可以直接在GridView属性中设置,多个字段之间用逗号分隔,如:DataKeyNames="ID,Year,WeekNum" 。

在用代码绑定GridView时,也可以设置DataKeyNames:

clip_image001

也可以在后台设定DataKeyNames 值

1 gv.DataSource = Bind();

2

3 gv.DataKeyNames = new string[]

4 {

5 "Id","Name","Sex"

6 };

7

8 gv.DataBind();

clip_image001[1]

DataKeyNames设置好以后,就可以用DataKeys来访问DataKeyNames中每个字段的值了,假如写在RowDeleting事件中

protected void gvWLBS_RowDataBound(object sender, GridViewRowEventArgs e)

{

//为GridView控件中的每一行添加双击事件

if (e.Row.RowType == DataControlRowType.DataRow) //这里一定要判断是数据行

{

string ID = DataBinder.Eval(e.Row.DataItem, "ID").ToString(); //第一种获取DataKeyNames中值的方式

//下面是第二种获取DataKeyNames中值的方式

string Year = gvWLBS.DataKeys[e.Row.RowIndex].Values["Year"].ToString(); //得到当前行数据Year

string WeekNum = gvWLBS.DataKeys[e.Row.RowIndex].Values["WeekNum"].ToString(); //得到当前行数据WeekNum

e.Row.Attributes["style"] = "Cursor:hand";

e.Row.Attributes.Add("OnDblClick", "editProjWeekReport(" + Year + "," + WeekNum + "," + ID + ")"); //双击事件

e.Row.ToolTip = "双击该行,编辑该行信息。"; //鼠标放上提示信息

}

}

可以这样用的原因:

当你设置了DataKeyNames属性,它保存了指定数据库中想要获取值的列名,该属性会自动填充到GridView控件的DataKeys集合

posted @ 2014-01-21 11:25  weifb  阅读(152)  评论(0)    收藏  举报