4

我有一个gridviewMain。每当我单击第 1 行的关闭链接按钮时,我都想获得值 aa。单击第 2 行上的关闭获取 bb 的值。有任何想法吗。

A    B   C  
aa  xx   3  CLOSE 
bb  yy   4  CLOSE
cc  zz   5  CLOSE

aspx

 <asp:BoundField DataField="afield" HeaderText="A" 
     SortExpression="afield" >
    <ItemStyle HorizontalAlign="Center" />
 </asp:BoundField>
 <asp:BoundField DataField="bfield" HeaderText="B" SortExpression="cfield" >
     <ItemStyle HorizontalAlign="Center" />
  </asp:BoundField>
  <asp:BoundField DataField="cfield" HeaderText="C" SortExpression="cfield" >
     <ItemStyle HorizontalAlign="Center" />
   </asp:BoundField>
 <asp:TemplateField ShowHeader="False">

       <ItemTemplate>
          <asp:LinkButton ID="lbClose" runat="server" CausesValidation="False"  CommandName="CloseClicked" Text="Close"></asp:LinkButton>

        </ItemTemplate>

                    </asp:TemplateField>
4

4 回答 4

15

假设您正在使用BoundFields前三列并且您想要处理-click 事件(而不是的LinkButtoneg ):RowCommandGridView

protected void CloseLinkClicked(Object sender, EventArgs e)
{
    var closeLink = (Control) sender;
    GridViewRow row = (GridViewRow) closeLink.NamingContainer;
    string firstCellText = row.Cells[0].Text; // here we are
}

如果您正在使用TemplateFields并且值aa在标签中(例如LblValue):

Label lblValue = (Label) row.FindControl("LblValue"); // lblValue.Text = "aa"
于 2013-06-28T13:51:10.757 回答
3

为此使用数据键。简单得多:

<asp:GridView ID="GridView1" runat="server" DataKeyNames="SomeValue, AnotherValue" ... >

然后在代码隐藏中,只需获取与该行关联的键:

var rowIndex = 0;
var someValue = GridView1.DataKeys[rowIndex]["SomeValue"] as string;
于 2013-06-28T14:32:37.567 回答
0

You can get like this

<asp:GridView ID="grid" runat="server" 
AutoGenerateColumns="false" onrowcommand="grid_RowCommand" >
<Columns>
<asp:TemplateField >
<ItemTemplate>
<asp:TextBox ID="txt" runat="server" Text='<%#Eval("xxx")%>'></asp:TextBox>
</ItemTemplate>
</asp:TemplateField>
<asp:TemplateField >
<ItemTemplate>
<asp:LinkButton ID="lnk" CommandArgument=<%# Container.DataItemIndex + 1 %> 
CommandName="arg">Click</asp:LinkButton>
</ItemTemplate>
</asp:TemplateField>
</Columns>
</asp:GridView>

Code

 protected void grid_RowCommand(object sender, GridViewCommandEventArgs e)
{
int rowindex = int.Parse(e.CommandArgument.ToString());
((TextBox)(grid.Rows[rowindex].FindControl("txtgvunit"))).Text
} 

Ref http://dotnetinbox.blogspot.in/2014/02/get-gridview-row-data-in-c.html

于 2014-02-04T13:22:03.427 回答
0

您需要在标记中CommandName为您的LinkButton列分配一个。GridView从那里您还需要连接OnRowCommand事件以处理您的Close命令。

Add这是在 a 上使用命令的示例GridView

Markup:
<asp:gridview id="ContactsGridView" datasourceid="ContactsSource" allowpaging="true" 
    autogeneratecolumns="false" onrowcommand="ContactsGridView_RowCommand" runat="server">
    <columns>
       <asp:buttonfield buttontype="Link" commandname="Add" text="Add"/>
       <asp:boundfield datafield="ContactID" headertext="Contact ID"/>
       <asp:boundfield datafield="FirstName" headertext="First Name"/> 
       <asp:boundfield datafield="LastName" headertext="Last Name"/>
    </columns>
</asp:gridview>

Code-Behind:
void ContactsGridView_RowCommand(Object sender, GridViewCommandEventArgs e)
{
    // If multiple buttons are used in a GridView control, use the
    // CommandName property to determine which button was clicked.
    if(e.CommandName=="Add")
    {
        // Convert the row index stored in the CommandArgument
        // property to an Integer.
        int index = Convert.ToInt32(e.CommandArgument);

        // Retrieve the row that contains the button clicked 
        // by the user from the Rows collection.
        GridViewRow row = ContactsGridView.Rows[index];

        // Create a new ListItem object for the contact in the row.     
        ListItem item = new ListItem();
        item.Text = Server.HtmlDecode(row.Cells[2].Text) + " " +
        Server.HtmlDecode(row.Cells[3].Text);

        // If the contact is not already in the ListBox, add the ListItem 
        // object to the Items collection of the ListBox control. 
        if (!ContactsListBox.Items.Contains(item))
        {
            ContactsListBox.Items.Add(item);
        }
    }
}
于 2013-06-28T13:56:10.797 回答