- 获取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")
- {
- GridViewRow drv = ((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent));
- inf id=Convert.ToInt32(GridView1.DataKeys[drv.RowIndex].Value);
-
- GridViewRow drv = ((GridViewRow)(((LinkButton)(e.CommandSource)).Parent.Parent));
-
- int id = Convert.ToInt32(GridView1.Rows[drv.RowIndex].Cells[0].Text);
-
-
- int id = Convert.ToInt32(e.CommandArgument.ToString());
-
-
- 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;
- string b = e.CommandArgument;
- }
- }
- 或:
- 如果是使用模板列,可以把数据的任意一列绑定到按钮的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()) 获取行索引了
posted @
2009-07-28 09:29
与时俱进
阅读(
1987)
评论()
编辑
收藏
举报