GridView控件当前行索引RowCommand和主键DataKeyNames应用

在用GridView控件时,我们经常会碰到获取当前行的索引,通过索引进行许多操作。例如,可以获得当前行某一个控件元素;设置某一元素的值等等。

下面结合实例介绍几种获得GridView当前行索引值的方法。

实例:

① 目的:获取GridView中RowCommand的当前索引行。

② 前台页面:在GridView中添加一模版列,里面添加一个LinkButton控件。

代码:

           

                   

                     CommandArgument='<%# Eval("Id") %>'>签入  

                     签出                     

                   

小提示:如果在后台代码中用e.CommandArgument取值的话,前台代码就必须在按钮中设置CommandArgument的值,值为绑定的数据库字段。如:

//因为在客户端中就已经将LinkButton的CommandArgument与主键Id给绑定了所以在此可以直接用e.CommandArgument得出主键ID的值

int id = Convert.ToInt32(e.CommandArgument.ToString());

③ 在GridView里已经设置了LinkButton为事件处理按钮,将通过以下方法获取索引:

protected void gv_Company_RowCommand(object sender, GridViewCommandEventArgs e){

if (e.CommandName == "QianRu")

{  

【方法一】

GridViewRow drv = ((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被选中的索引值

inf id=Convert.ToInt32(GridView1.DataKeys[drv.RowIndex].Value); //此获取的值为GridView中绑定数据库中的主键值

注意:运用此方法,需要对GridView的DataKeyNames属性进行设置,此例中设置为主键字段。

【方法二】

GridViewRow drv = (GridViewRow)((LinkButton)e.CommandSource).NamingContainer;//此得出的值是表示那行被选中的索引值

int id = Convert.ToInt32(GridView1.Rows[drv.RowIndex].Cells[0].Text);   //此获取的值为GridView中绑定数据库中的主键值,取值方法是选中的行中的第一列的值,drv.RowIndex取得是选中行的索引

}

}

 

此外,还有一些方法可以实现获得当前行索引值。

【方法三】在linkbutton控件的Command事件,利用sender的Parent获取GridView中的当前行。

                   protected void lbtnQianChu_Command(object sender, CommandEventArgs e)

                   {

                    LinkButton lb = (LinkButton)sender;

                            DataControlFieldCell dcf = (DataControlFieldCell)lb.Parent;

                            GridViewRow gvr = (GridViewRow)dcf.Parent; //此得出的值是表示那行被选中的索引值

                            lbtnQianChu.SelectedIndex = gvr.RowIndex;

                   }

【方法四】在linkbutton控件的Click事件,获取GridView中的当前行。

protected void LinkButton1_Click(object sender, EventArgs e)

{

      //行号

      int row = ((GridViewRow)((LinkButton)sender).NamingContainer).RowIndex;

}

【方法五】如果在模板列中添加一下DropDownList控件,并开启其AutoPostback属性,在DropDownList 的SelectedIndexChanged事件中,获取GridView中的当前行。

下面是SelectedIndexChanged事件的代码摘要:

DropDownList ddl = (DropDownList)sender;

GridViewRow gvr = (GridViewRow)ddl.NamingContainer;

int id = int.Parse(GridView1.DataKeys[gvr.RowIndex][0].ToString());

int num = int.Parse(ddl.Text);

第一句用来获取触发事件的DropDownList控件。

第二句就利用该控件的NamingContainer属性,获取其容器,也就是GridViewRow对象。

 

提示:由于DropDoweList与button不同,无法指定其CommandName,所以,通过用NamingContainer属性来解决问题。

    先来看看微软对该NamingContainer属性的解释:

    获取对服务器控件的命名容器的引用,此引用创建唯一的命名空间,以区分具有相同 Control.ID 属性值的服务器控件。

    ASP.NET Web 应用程序的每一页均包含控件的层次结构。此层次结构与控件是否生成用户可见的 UI 无关。给定控件的命名容器是层次结构中该控件之上的父控件,此父控件实现 INamingContainer 接口。实现此接口的服务器控件为其子服务器控件的 ID 属性值创建唯一的命名空间。

    当针对列表 Web 服务器控件(如 Repeater 和 DataList 服务器控件)进行数据绑定时,为服务器控件创建唯一的命名空间尤其重要。当数据源中的多个项创建服务器控件的多个实例,且该服务器控件是重复控件的子级时,命名容器确保这些子控件的每个实例具有不冲突的 UniqueID 属性值。页的默认命名容器是请求该页时生成的 Page 类的实例。

可以使用此属性确定特定服务器控件所在的命名容器。

 

【方法六】如果模板列中有CheckBox控件的情况,通过CheckBox1_CheckedChanged事件中,获取GridView中的当前行。

CheckBox chk = (CheckBox)sender;

DataControlFieldCell dcf = (DataControlFieldCell)chk.Parent;

GridViewRow gvr = (GridViewRow)dcf.Parent;

 

【方法七】

        

       

       

       

        DisplayIndex : <%# Container.DisplayIndex %> || DataItemIndex : <%# Container.DataItemIndex %>

       

       

       

 

 


GridView的DataKeyNames的一些用法2009-04-09 17:55页面前台有以下代码:
  
  
  后台有以下代码:
  protected void View1_RowDataBound(object sender,GridViewRowEventArgs e)
  {
   if(View1.DataKeys[e.Row.RowIndex].Values["Mode"].ToString().ToLower() == "false")
   {
   ......
   }
  }
  
  说明:
  由于为GridView控件的DataKeyNames属性设置了表的两个字段(SubjectID,Mode),因此可以在为GridView绑定数据时对库表的每个记录的指定字段值作出判断。后台代码中的e.Row.RowIndex即表示GridView的当前行(对应于库表的当前记录);而View1.DataKeys[e.Row.RowIndex].Values["Mode"].ToString()则获取当前行指定字段(Mode)的值。若前台代码只写:DataKeyNames="SubjectID'(即DataKeyNames属性只填入一个字段名),则后台只需写成: View1.DataKeys[e.Row.RowIndex].Value.ToString()) 即可。
  同样的,要动态获取当前行另一个字段的值可以这样写: View.DataKeys[e.Row.RowIndex].Values["SubjectID"].ToString()).当参数为一个时可用或者View.DataKeys[e.Row.RowIndex].Value.ToString())。
  
  总之,为GridView的DataKeyNames属性设置库表字段名的主要目的还是为了在为GridView控件绑定数据时获取当前行指定字段的值,以便作相应处理。若无此需求的话则GridView的DataKeyNames属性就可以不设置。

----------------------------------------------------------------------------------------------------------------------------------

在我们使用GridView的过程中,经常会遇到这样对问题,我们选择某一行进行编辑,或选择某一行删除或者.......时,我们需要获取当前行的某些信息,尤其是当前行的主键信息,主键信息一般不显示在页面,此时我们有三种方法来处理。
第一种是使用DataKeyNames ,这里只重点介绍这个。
第二种是使用按钮的CommandArgument属性邦定需要的信息。
第三种是最古老最通用的方法使用隐藏的方法显示。

第一种方法:使用DataKeyNames,DataKeyNames可邦定一列,也可邦定多列
前台:DataKeyNames="FID"   绑定一个值
后台:GridView1.DataKeys[e.Row.RowIndex].Value.ToString();

前台:DataKeyNames="FID,FName"   绑定两个值
后台:GridView1.DataKeys[e.Row.RowIndex].Values[0].ToString();
后台:GridView1.DataKeys[e.Row.RowIndex].Values[1].ToString();
或者
后台:GridView1.DataKeys[e.Row.RowIndex].Values["FID"].ToString();
后台:GridView1.DataKeys[e.Row.RowIndex].Values["FName"].ToString();

你可能感兴趣的:(Asp.net)