【问题标题】:asp.net C# Gridview nested gridviewasp.net C# Gridview 嵌套gridview
【发布时间】:2017-04-04 22:31:30
【问题描述】:

亲爱的所有天才,请帮助我解决这个问题,一直在尝试,但没有运气。我正在尝试为单个父行打开我的嵌套网格视图,但使用子行的一个记录打开整个父行。应该是当我单击父 gridview 行的按钮时,特定行的记录应该显示在同一父行的子 gridview 中,但在我的情况下,父行的记录会显示并且子 gridview 会打开在所有父行中。请需要帮助:( enter image description here

<asp:GridView runat="server" ID="GridView4" AllowPaging="True"
    AutoGenerateColumns="False" DataKeyNames="UId" class="" CellPadding="4" PageSize="5">
    <AlternatingRowStyle BackColor="White" />
    <Columns>
        <asp:TemplateField HeaderText="File Type" Visible="false">

            <ItemTemplate>
                <asp:Label ID="lblFileType" runat="server" Text='<%# Eval("FileType") %>'></asp:Label>
            </ItemTemplate>
            <HeaderStyle HorizontalAlign="Left" VerticalAlign="Middle" Width="10%" />
            <ItemStyle HorizontalAlign="Left" VerticalAlign="Middle" Width="10%" />
        </asp:TemplateField>

        <asp:TemplateField HeaderText="Image Name" Visible="false">

            <ItemTemplate>
                <asp:Label ID="lblImageName" runat="server" Text='<%# Eval("ImageName") %>'></asp:Label>
            </ItemTemplate>
            <HeaderStyle HorizontalAlign="Left" VerticalAlign="Middle" Width="10%" />
            <ItemStyle HorizontalAlign="Left" VerticalAlign="Middle" Width="10%" />
        </asp:TemplateField>

        <asp:TemplateField HeaderText="">
            <ItemTemplate>
                <asp:ImageButton ID="Image2" class="img1" runat="server" ImageUrl='<%# Bind("pic") %>' OnCommand="blah_Command" CommandName='<%# Eval("UId") %>' CommandArgument='<%# Eval("pic") %>' />

                <asp:Panel ID="pnlOrders" runat="server" Style="position: relative" Visible="false">
                    <asp:GridView ID="gvOrders" runat="server" AutoGenerateColumns="false" CssClass="ChildGrid">
                        <Columns>
                            <asp:BoundField ItemStyle-Width="150px" DataField="FileSize" HeaderText="Order Id" />
                            <asp:BoundField ItemStyle-Width="150px" DataField="ShareByUserId" HeaderText="Date" />
                        </Columns>
                    </asp:GridView>
                </asp:Panel>

            </ItemTemplate>

        </asp:TemplateField>

    </Columns>
    <FooterStyle BackColor="#ffffff" Font-Bold="True" ForeColor="White" />
    <HeaderStyle BackColor="#ffffff" Font-Bold="True" ForeColor="White" />

</asp:GridView>

代码背后:

protected void blah_Command(object sender, CommandEventArgs e)
{
    foreach (GridViewRow row2 in GridView4.Rows)
    {
        row2.FindControl("pnlOrders").Visible = true;

        string customerId = e.CommandName.ToString();
        GridView gvOrders = row2.FindControl("gvOrders") as GridView;
        BindOrders(customerId, gvOrders);
    }
}

private void BindOrders(string customerId, GridView gvOrders)
{
    gvOrders.ToolTip = customerId;
    gvOrders.DataSource = GetData(string.Format("select * from SShare where UId='{0}'", customerId));
    gvOrders.DataBind();
} 

【问题讨论】:

  • 代码大部分是正确的。请在查询中使用参数。首先你为什么写:foreach (GridViewRow row2 in GridView4.Rows)?使用发件人和相关容器而不是该代码。如果它不能修复,你可以尝试在没有 ImageButton 的 RowDataBound 事件中完成这一切吗?我建议改变你的思维方式:GridvView 很难以这种方式使用。您可以使用叠加层(厚框、颜色框...)并在其中打开嵌套的 GridView。或者你执行你的目标客户端......
  • @Emanuele 谢谢,让我检查并再试一次。

标签: c# asp.net gridview


【解决方案1】:

您正在循环GridView4 中的所有行,因此每个嵌套的 GridView 都将填充数据。 您需要的是单击的 LinkBut​​ton 所在行的行号,并使用它来查找嵌套的 GridView。

protected void blah_Command(object sender, CommandEventArgs e)
{
    //get the current datagrid item from the sender
    GridViewRow row = (GridViewRow)(((Control)sender).NamingContainer);

    //the row index of the gridviewrow
    int rowIndex = row.RowIndex;

    //find the correct nested grid using the row index
    GridView gvOrders = GridView4.Rows[rowIndex].FindControl("gvOrders") as GridView;
}

【讨论】:

  • protected void blah_Command(object sender, CommandEventArgs e) { ImageButton imgshow = (sender as ImageButton); GridViewRow 行 = (imgshow.NamingContainer as GridViewRow); row.FindControl("pnlOrders").Visible = true; GridView gvOrders = GridView4.Rows[rowIndex].FindControl("gvOrders") as GridView;字符串 customerId = e.CommandName.ToString(); BindOrders(customerId, gvOrders); }