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

实例: 
① 目的:获取GridView中RowCommand的当前索引行。 
② 前台页面:在GridView中添加一模版列,里面添加一个LinkButton控件。 
代码: 
<asp:TemplateField HeaderText="操作"> 
<ItemTemplate> 
<asp:LinkButton ID="lbtnQianRu" runat="server" CommandName="QianRu" 
CommandArgument='<%# Eval("Id") %>'>签入</asp:LinkButton> 
<asp:LinkButton ID="lbtnQianChu " runat="server" CommandName="QianChu">签出 </asp:LinkButton> 
</ItemTemplate> 
</asp:TemplateField> 
小提示:如果在后台代码中用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;

【方法七】

<asp:GridView ID="gvTest" runat="server"> 
<Columns> 
<asp:TemplateField> 
<ItemTemplate> 
DisplayIndex : <%# Container.DisplayIndex %> || DataItemIndex : <%# Container.DataItemIndex %><br /> 
</ItemTemplate> 
</asp:TemplateField> 
</Columns> 
</asp:GridView>

【方法八】

控件的ID和Name命名可以如上方法,我需要通过RowCommand()方法判断选中的是哪一列,而要使用这个方法的前提是,e.CommandArgument这么一个属性(首先必须知道在GridView里,行索引是被放在CommandArgument里面的),现在的任务就是获得这么一个属性。查资料可以知道,在创建GridView控件中每一行时,都将引发一个RowCreated事件,借此这么个方法,可以把linkButton所选择的行号写入CommandArgument中。 
protected void gvInfo_RowCreated(object sender, GridViewRowEventArgs e) 

if (e.Row.RowType == DataControlRowType.DataRow) 

LinkButton lk1 = (LinkButton)e.Row.FindControl("lkbtn");//LinkButton的ID 
lk1.CommandArgument = e.Row.RowIndex.ToString(); 


protected void gvInfo_RowCommand(object sender, GridViewCommandEventArgs e) 

if (e.CommandName == "ADD")//我LinkButton的CommandName 

int index = Convert.ToInt32(e.CommandArgument); 
string aa = gvInfo.Rows[index].Cells[1].Text.ToString();//获取当前行列号为一的值,列号从0开始 

}

ASP.NET中gridview获取当前行的索引值相关推荐

  1. 老狗——GridView获取当前行的索引

    在用GridView控件时,我们经常会碰到获取当前行的索引,通过索引进行许多操作.例如,可以获得当前行某一个控件元素:设置某一元素的值等等. 下面结合实例介绍几种获得GridView当前行索引值的方法 ...

  2. gridview获取当前行索引的方法

    在用GridView控件时,我们经常会碰到获取当前行的索引,通过索引进行许多操作.例如,可以获得当前行某一个控件元素:设置某一元素的值等等. 下面结合实例介绍几种获得GridView当前行索引值的方法 ...

  3. Asp.net中GridView使用详解(引)【转】

    Asp.net中GridView使用详解(引) GridView无代码分页排序 GridView选中,编辑,取消,删除 GridView正反双向排序 GridView和下拉菜单DropDownList ...

  4. miniui datagrid java_[Java教程]MiniUI DataGrid获取当前行某列值

    [Java教程]MiniUI DataGrid获取当前行某列值 0 2015-10-28 20:00:17 前言: 本文将给大家介绍一下, miniUI官网没有涉及到的内容:如何获取当前行某一列的值? ...

  5. php 获取日期标签的值,在php中获取标签的选定索引值

    我试图从< select>中获取所选值在 PHP中标记,但我收到错误. 这就是我所做的, HTML Select Male Female PHP脚本 $Gender = $_POST[&q ...

  6. C#中如何获取一个字体的宽度值(像素单位)-获得文字的像素宽度

    C#中如何获取一个字体的宽度值(像素单位) 应用:减去了一个空格的长, 字符间距还是有点差距 private void listBox1_DrawItem(object sender, DrawIte ...

  7. jquery 获取当前元素的索引值

    jquery 获取当前元素的索引值 $("#lisa > li").mouseover(function(){ alert($("#lisa > li&quo ...

  8. java怎么获取索引值,Java 实例 - 获取向量元素的索引值

    以下实例演示了使用 Collections 类的 sort() 方法对向量进行排序并使用 binarySearch() 方法来获取向量元素的索引值: /* author by shouce.ren M ...

  9. asp.net中GridView传多个值到其它页面的方法

    网站开发中,在页面之间的跳转,经常会用到传值,其中可能会传递多个值. 一.CommadArgument传多个值到其他页面. 像Gridview dataList repeater等数据绑定控件中,可以 ...

最新文章

  1. 人脸识别引爆下一代生物支付四军之战
  2. python timer使用-Python timer定时器两种常用方法解析
  3. mysql stragg_如何在MySQL中將子查詢行的結果顯示為一列?
  4. android生成aar无效,android studio生成aar包并在其他工程引用aar包的方法
  5. Android studio gradle task list 不显示问题
  6. 最优化学习笔记(六)——牛顿法性质分析
  7. Android:自定义滚动边缘(EdgeEffect)效果
  8. 运动目标跟踪(十六)--OAB,SemiT,BSBT跟踪
  9. 七牛上传自有证书(crt格式证书转为pem格式)
  10. 名企工资一览表--最新更新
  11. 2020第三届中青杯问题总结
  12. 黑马程序员 接口 总结
  13. 安装 Vmware和创建虚拟机即密码破解
  14. vhg电路是什么意思_显示装置和电力监测电路的制作方法
  15. A problem occurred configuring project ‘:app‘.
  16. MSP430 BSL 下载
  17. 计蒜客 - 蒜头君的任务
  18. 家用千兆路由器排行榜前十名_求家用路由器排名前十名,有哪些比较推荐?
  19. Matlab中set-gca函数的使用
  20. flask-socketio实现的网页聊天室(一)

热门文章

  1. LeetCode 316. Remove Duplicate Letters--贪心--Java,C++,Python解法
  2. java抓取网页标题内容_[Java教程]java 网页页面抓取标题和正文
  3. sc修改服务器,华为sc服务器配置方法
  4. mysql 3.6.4_TOMCAT5+MYSQL5+JIRA3.6.4配置说明
  5. 贪吃蛇python零基础教程_自学python-tkinter项目-贪吃蛇的程序(0基础入门学习)...
  6. mysql表和表的关系_mysql表与表之间建关系
  7. Web 服务器-Apache详解
  8. bios显存改8g rx_【折腾】RX470矿卡刷BIOS变身记
  9. pythonwhile嵌套while_while嵌套if
  10. rea t插件 vscode_推荐VSCode12个比较实用的插件