• 获取GridView中RowCommand的当前选中行的索引或主键Id《转》


    获取GridView中RowCommand的当前选中行的索引或主键Id 收藏
    获取GridView中RowCommand的当前索引行 前台添加一模版列,里面添加一个LinkButton
    前台 (如果在后台代码中用e.CommandArgument取值的话前台代码就必须在按钮中设置CommandArgument的值,值为绑定的数据库字段
    <asp:TemplateField HeaderText="操作">
        <ItemTemplate>
            <asp:LinkButton ID="LinkButton1" runat="server" CommandName="QianRu"
            CommandArgument='<%# Eval("Id") %>'>签入</asp:LinkButton>  
            <asp:LinkButton ID="LinkButton2" runat="server" CommandName="QianChu">签出</asp:LinkButton>
        </ItemTemplate>
    </asp:TemplateField>


    后台
    在GridView里已经设置了LinkButton为事件处理按钮,将通过以下方法获取索引
    protected void gv_Company_RowCommand(object sender, GridViewCommandEventArgs e){
            if (e.CommandName == "QianRu")
        {     //取ID的值方法一   
                  GridViewRow drv = ((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被选中的索引值
                  inf id=Convert.ToInt32(GridView1.DataKeys[drv.RowIndex].Value); //此获取的值为GridView中绑定数据库中的主键值

              //取ID的值方法二   
                  GridViewRow drv = ((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent)); //此得出的值是表示那行被选中的索引值
                  //此获取的值为GridView中绑定数据库中的主键值,取值方法是选中的行中的第一列的值,drv.RowIndex取得是选中行的索引
              int id = Convert.ToInt32(GridView1.Rows[drv.RowIndex].Cells[0].Text);

              //取ID的值方法三  
              //因为在客户端中就已经将LinkButton的CommandArgument与主键Id给绑定了所以在此可以直接用e.CommandArgument得出主键ID的值
              int id = Convert.ToInt32(e.CommandArgument.ToString());


    //取ID的值方法四
              //此方法不需在模板列中设置CommandArgument的值
              string index=e.CommandArgument.ToString(); //那行被选中,取出选中行的索引
              int id=Convert.ToInt32(GridView1.Rows[Convert.ToInt32(index)].Cells[0].Text);
            }
        }


    还有一种就是我们并不需要知道当前点击的是第几行,可以用以下方法实现要求:
    <ItemTemplate>
          <asp:LinkButton ID="LinkButton1" runat="server" CommandArgument=' <%# Eval("field1") %>'
          CommandName="play" Text=' <%# Eval("field2") %>'> </asp:LinkButton>
    </ItemTemplate>

    上面这个LinkButton,Text绑定了字段2, CommandArgument绑定了字段1
    那么,
    protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
    {
        if(e.CommandName="play")
        {
            LinkButton lb = (LinkButton)e.CommandSource;
            string a = lb.Text;//这里可以获得点击行字段field2的值
            string b = e.CommandArgument;//这里可以获得点击行字段field1的值
        }
    }

    或:
    如果是使用模板列,可以把数据的任意一列绑定到按钮的CommandArgument,如下:

    <asp:TemplateField>

    <ItemTemplate>

    <asp:Button runat="server" CommandArgument='<%# Eval("id") %>' Text="Button" />

    </ItemTemplate>

    </asp:TemplateField>

    一般可以绑定到主键列,这样可以在RowCommand通过e.CommandArgument获取当前行的主键,也便于进行其他操作

    如果是要获取行索引,比较麻烦一点,还是那个Button1,在GridView的RowDataBound事件中如下:

    Button btn = (Button)e.Row.FindControl("Button1");
    if (btn != null)
    {
    btn.CommandArgument = e.Row.RowIndex.ToString();
    }
    这样就可以在RowCommand中通过 int rowId=Convert.ToInt32(e.CommandArgument.ToString()) 获取行索引了

  • 相关阅读:
    Kettle使用kettle.properties
    kettle 获取文件名
    连接池的补充设置,应用到上面所有数据源中
    kettle 获取某个目录下所有的文件
    不小心删库了怎么办,用binlog可以恢复
    江北的KETTLE学习日志
    Python3 中,bytes 和 str
    kettle入门(四) 之kettle取昨天时间&设置任意时间变量案例
    30-Day Leetcoding Challenge Day17(构造并查集)
    30-Day Leetcoding Challenge Day16
  • 原文地址:https://www.cnblogs.com/kingwangzhen/p/1657986.html
Copyright © 2020-2023  润新知