1. 获取GridView中RowCommand的当前索引行 前台添加一模版列,里面添加一个LinkButton
  2. 前台 (如果在后台代码中用e.CommandArgument取值的话前台代码就必须在按钮中设置CommandArgument的值,值为绑定的数据库字段
  3. <asp:TemplateField HeaderText="操作">
  4. <ItemTemplate>
  5. <asp:LinkButton ID="LinkButton1" runat="server" CommandName="QianRu"
  6. CommandArgument='<%# Eval("Id") %>'>签入</asp:LinkButton>
  7. <asp:LinkButton ID="LinkButton2" runat="server" CommandName="QianChu">签出</asp:LinkButton>
  8. </ItemTemplate>
  9. </asp:TemplateField>
  10. 后台
  11. 在GridView里已经设置了LinkButton为事件处理按钮,将通过以下方法获取索引
  12. protected void gv_Company_RowCommand(object sender, GridViewCommandEventArgs e){
  13. if (e.CommandName == "QianRu")
  14. {     //取ID的值方法一
  15. GridViewRow drv = ((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被选中的索引值
  16. inf id=Convert.ToInt32(GridView1.DataKeys[drv.RowIndex].Value); //此获取的值为GridView中绑定数据库中的主键值
  17. //取ID的值方法二
  18. GridViewRow drv = ((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被选中的索引值
  19. //此获取的值为GridView中绑定数据库中的主键值,取值方法是选中的行中的第一列的值,drv.RowIndex取得是选中行的索引
  20. int id = Convert.ToInt32(GridView1.Rows[drv.RowIndex].Cells[0].Text);
  21. //取ID的值方法三
  22. //因为在客户端中就已经将LinkButton的CommandArgument与主键Id给绑定了所以在此可以直接用e.CommandArgument得出主键ID的值
  23. int id = Convert.ToInt32(e.CommandArgument.ToString());
    1. //取ID的值方法四
    2. //此方法不需在模板列中设置CommandArgument的值
    3. string index=e.CommandArgument.ToString(); //那行被选中,取出选中行的索引
    4. int id=Convert.ToInt32(GridView1.Rows[Convert.ToInt32(index)].Cells[0].Text);

    }

  24. }
  25. 还有一种就是我们并不需要知道当前点击的是第几行,可以用以下方法实现要求:
  26. <ItemTemplate>
  27. <asp:LinkButton ID="LinkButton1" runat="server" CommandArgument=' <%# Eval("field1") %>'
  28. CommandName="play" Text=' <%# Eval("field2") %>'> </asp:LinkButton>
  29. </ItemTemplate>
  30. 上面这个LinkButton,Text绑定了字段2, CommandArgument绑定了字段1
  31. 那么,
  32. protected  void  GridView1_RowCommand(object  sender,  GridViewCommandEventArgs  e)
  33. {
  34. if(e.CommandName="play")
  35. {
  36. LinkButton lb = (LinkButton)e.CommandSource;
  37. string  a  =  lb.Text;//这里可以获得点击行字段field2的值
  38. string b = e.CommandArgument;//这里可以获得点击行字段field1的值
  39. }
  40. }
  41. 或:
  42. 如果是使用模板列,可以把数据的任意一列绑定到按钮的CommandArgument,如下:
  43. <asp:TemplateField>
  44. <ItemTemplate>
  45. <asp:Button runat="server" CommandArgument='<%# Eval("id") %>' Text="Button" />
  46. </ItemTemplate>
  47. </asp:TemplateField>
  48. 一般可以绑定到主键列,这样可以在RowCommand通过e.CommandArgument获取当前行的主键,也便于进行其他操作
  49. 如果是要获取行索引,比较麻烦一点,还是那个Button1,在GridView的RowDataBound事件中如下:
  50. Button btn = (Button)e.Row.FindControl("Button1");
  51. if (btn != null)
  52. {
  53. btn.CommandArgument = e.Row.RowIndex.ToString();
  54. }
  55. 这样就可以在RowCommand中通过 int rowId=Convert.ToInt32(e.CommandArgument.ToString()) 获取行索引了

转载于:https://www.cnblogs.com/juan/archive/2009/03/31/1425928.html

获取GridView中RowCommand的当前选中行的索引或主键Id相关推荐

  1. 获取GridView中RowCommand的当前索引行

    获取GridView中RowCommand的当前索引行 前台添加一模版列,里面添加一个Button <asp:TemplateField HeaderText="测试"> ...

  2. mybatis多表新增如何获取主键ID

    记录一下碰到的问题,就当做是笔记吧,防止忘记.在做ssm多表新增的时候,碰到了一个小问题,就是在新增成功一个表的时候我要获取它的ID,然后用它的ID新增下一个表. 但是,我要怎么做呢?新增成功,再查询 ...

  3. Mybatis 在 insert 之后想获取自增的主键 id,但却总是返回1

    记录一次傻逼的问题, 自己把自己蠢哭:Mybatis 在 insert 之后想获取自增的主键 id,但却总是返回1 错误说明: 返回的1是影响的行数,并不是自增的主键id: 想要获取自增主键id,需要 ...

  4. 做工作流时候 Mybatis 在 insert 之后想获取自增的主键 id,但却总是返回1

    Mybatis 在 insert 之后想获取自增的主键 id,但却总是返回1 错误说明: 返回的1是影响的行数,并不是自增的主键id: 想要获取自增主键id,需要通过xx.getId()方法获取,因为 ...

  5. MySQL获取自增主键Id

    mysql插入数据后返回自增ID的方法   mysql和oracle插入的时候有一个很大的区别是,oracle通过获取序列的方式得到主键,mysql本身有一个列可以做自增长字段,mysql在插入一条数 ...

  6. python 类 实例id递增_Python Django 模板类中 系统默认的主键ID自增,不会随着模板实例的删除而重置问题...

    题目描述 在django中创建两个模板实例后,删除后重新再创建一个模板实例后它的主键ID从3开始这是为什么? 怎样解决这个问题? 相关代码 modeles类: from django.db impor ...

  7. MySQL中的索引(主键索引)

    MySQL中的索引(主键索引篇) 主键索引是一种特殊的唯一索引,一个表只能有一个主键,不允许有空值.一般是在建表的时候同时添加主键索引: 一.如何添加主键索引 修改表添加主键索引 Alter tab ...

  8. oracle和mybatis自增,在Springboot项目中使用MybatisPlus和Oracle实现主键ID的自增

    在Springboot项目中使用MybatisPlus和Oracle实现主键ID的自增 发布时间:2020-11-18 15:49:35 来源:亿速云 阅读:125 作者:Leah 在Springbo ...

  9. es中document的主键id及局部更新

    很多介绍es的文章,都会说一下lucene的不足,其中两条有迷惑: 1. lucene的document没有全局唯一的主键id 2. lucene不支持更新. 疑惑点1:没有主键id. 可以用luce ...

最新文章

  1. html页面转换成pdf
  2. Oracle WebCenter 11g 快速开发指南--翻译(一)
  3. day01: oracle12C在Linux7.5上图形化安装部署方法:
  4. 平顶山学院java实验室_重点学科(实验室)建设规划
  5. c语言实现linux下的top命令来获取cpu利用率_有用的一篇笔记,linux 调优各项监控指标...
  6. HttpClient 如何正确的释放资源
  7. java文件迁移工具,Java的迁移
  8. java actor和线程有什么区别_java – 在Akka Actors中使用OpenGL:保证单个线程用于特定的actor...
  9. Fortran 95 流程控制、循环
  10. 商业软件、共享软件和自由软件
  11. layui的layer弹出层和form表单
  12. 蓝桥杯 完全二叉树的权值
  13. 编程java好学吗,java初级编程好学吗
  14. mysql 数据转移历史表_mysql 历史数据表迁移方案
  15. Redis数据库(入门)
  16. 数组中a与a[0]的区别
  17. CoinGecko 播客:与 Cartesi 联合创始人 Erick 一起构建 Layer-2
  18. 你不能错过的文章撰写软件
  19. 微服务架构之限流熔断
  20. 1162开放英语4 (2)

热门文章

  1. 61-1 认识webpack
  2. Python Socket通信黏包问题分析及解决方法
  3. Swagger+Spring mvc生成Restful接口文档
  4. [Node.js]get/post请求
  5. 我国域名***日均58起 高安全DNS防御系统建设刻不容缓
  6. 用ElasticSearch存储日志
  7. //获取本地IP地址和对端IP地址
  8. Oracle 数据库实例启动关闭过程
  9. OSPF动态路由协议入门简介
  10. Linux下V4L2编程小结