如何从gridview中使用链接按钮的行填充多个文本框

时间:2013-10-25 21:17:36

标签: c# asp.net sql gridview

我正在尝试使用gridview中的数据填充多个文本框,当我单击链接按钮(实际上是每行中某个字段的名称)但它没有通过时。我是新手 - 这是我的第一次。非常感激任何的帮助。

protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e)
{
    if (e.CommandName == "Select")
    {
        int index = Convert.ToInt32(e.CommandArgument);
        GridViewRow selectedRow = GridView1.Rows[index];

        AccountNumber.Text = selectedRow.Cells[1].Text;
        Name.Text = selectedRow.Cells[1].Text;
        Address1.Text = selectedRow.Cells[1].Text;
        Address2.Text = selectedRow.Cells[2].Text;
        Address3.Text = selectedRow.Cells[3].Text;
        PhoneNumber.Text = selectedRow.Cells[4].Text;
        FaxNumber.Text= selectedRow.Cells[5].Text;
        CurrencyID.Text = selectedRow.Cells[6].Text;
    }
}

<asp:GridView ID="GridView1" runat="server" 
              AutoGenerateColumns="False" 
              DataKeyNames="Agent_Account_No" 
              DataSourceID="SqlDataSource1" 
              AlternatingRowStyle-BackColor ="Lavender" 
              HeaderStyle-BackColor="#9966FF" 
              AllowSorting="True" HeaderStyle-BorderColor="Black"    
              HorizontalAlign="Center" 
              RowStyle-BorderColor="Black" 
              EmptyDataText="There are no data records to display."  
              onrowcommand ="GridView1_RowCommand">
    <AlternatingRowStyle BackColor="#CCFFCC" />
    <Columns>
        <asp:BoundField datafield="Agent_Account_No" HeaderText="Account No" 
                        ItemStyle-HorizontalAlign="Center" 
                        ItemStyle-VerticalAlign="Middle" 
                        ItemStyle-Width="50" 
                        SortExpression="Agent_Account_No" 
                        ReadOnly="true"> 
            <ItemStyle HorizontalAlign="Center" VerticalAlign="Middle" 
                       Width="50px" />
        </asp:BoundField>
        <asp:TemplateField HeaderText="Name" SortExpression="Agent_Name">
            <ItemTemplate> 
                <asp:LinkButton ID="AgentName" runat="server" 
                                Text='<%# Eval("Agent_Name") %>' 
                                CommandName="Select" 
                                CommandArgument='<%#Bind("Agent_Name") %>'> 
                </asp:LinkButton> 
            </ItemTemplate>
        </asp:TemplateField>

2 个答案:

答案 0 :(得分:1)

我让它以这种方式工作 - 使用本网站的帮助:

protected void GridView1_SelectedIndexChanged(object sender, EventArgs e)
{
    GridViewRow row = GridView1.SelectedRow;        

    AccountNumber.Text = GridView1.DataKeys[row.RowIndex]["Agent_Account_No"].ToString();

    ......
}

我不知道这个声明是否正确,但它确实有效。但是现在它起作用我看到了一个我之前没有看到过的问题 - 看看我的个人资料并非常感谢!

答案 1 :(得分:0)

我强烈建议您为所有列使用TemplateField,例如:

标记:

<Columns>
    <asp:TemplateField HeaderText="Account No" SortExpression="Agent_Account_No">
        <ItemTemplate> 
            <asp:Label ID="LabelAccountNumber" runat="server" 
                       Text='<%# Eval("Agent_Account_No") %>'>
            </asp:Label> 
        </ItemTemplate>
    </asp:TemplateField>
    ...
    <asp:TemplateField HeaderText="Name" SortExpression="Agent_Name">
        <ItemTemplate> 
            <asp:LinkButton ID="AgentName" runat="server" 
                            Text='<%# Eval("Agent_Name") %>' 
                            CommandName="Select" 
                            CommandArgument='<%#Bind("Agent_Name") %>'>
            </asp:LinkButton> 
        </ItemTemplate>
    </asp:TemplateField>
</Columns>

现在在RowCommand方法中,您可以使用网格视图行的FindControl()方法来获取您感兴趣的文本,如下所示:

代码隐藏:

protected void GridView1_RowCommand(object sender, GridViewCommandEventArgs e) 
{ 
    if (e.CommandName == "Select") 
    { 
        int index = Convert.ToInt32(e.CommandArgument); 
        GridViewRow selectedRow = GridView1.Rows[index];

        // Find the account number label to get the text value for the text box
        Label theAccountNumberLabel = selectedRow.FindControl("LabelAccountNumber") as Label;

        // Make sure we found the label before we try to use it
        if(theAccountNumberLabel != null)
        {
            AccountNumber.Text = theAccountNumberLabel.Text;
        }
        // Follow the same pattern for the other labels to get other text values          
    }
}