Skip to main content

Nested GridView in ASP.NET Using c# with show/hide


In This example shows how to create Nested GridView In Asp.Net Using C# And VB.NET With Expand Collapse Functionality.

Sending Email from Asp.net With Dynamic Content , SQL Server- Case Sensitive Search in SQL Server


I have used JavaScript to Create Expandable Collapsible Effect by displaying Plus Minus image buttons.

Nested GridView Example In Asp.Net With Expand Collapse

Customers and Orders Table of Northwind Database are used to populate nested GridViews.

Drag and place SqlDataSource from toolbox on aspx page and configure and choose it as datasource from smart tags

Go to HTML source of page and add 2 TemplateField in <Columns>, one as first column and one as last column of gridview.

Place another grid in last templateField column.

Markup of page after adding both templatefields will like as shown below.



HTML SOURCE
     <asp:GridView ID="gvMaster" runat="server" 
                 AllowPaging="True" 
                   AutoGenerateColumns="False" 
                  DataKeyNames="CustomerID" 
                 DataSourceID="SqlDataSource1" 
                  onrowdatabound="gvMaster_RowDataBound">
    <Columns>
    <asp:TemplateField>
       <ItemTemplate>
       <a href="javascript:collapseExpand('customerID-
                 <%# Eval("CustomerID") %>');">
      <img id="imagecustomerID-<%# Eval("CustomerID") %>" 
             alt="Click to show/hide orders" 
            border="0" src="plus.png" /></a>
       </ItemTemplate>
   </asp:TemplateField>
   <asp:BoundField DataField="CustomerID" 
                   HeaderText="CustomerID"/>
   <asp:BoundField DataField="CompanyName" 
                    HeaderText="CompanyName"/>
     
    <asp:TemplateField>
    <ItemTemplate>
   <tr><td colspan="100%">
   <div id="customerID-<%# Eval("CustomerID") %>" 
        style="display:none;
         position:relative;left:25px;">
       
    <asp:GridView ID="nestedGridView" runat="server" 
                 AutoGenerateColumns="False" 
                  DataKeyNames="OrderID">
    <Columns>
   <asp:BoundField DataField="OrderID" HeaderText="OrderID"/>
    <asp:BoundField DataField="OrderDate" HeaderText="OrderDate"/>
   <asp:BoundField DataField="Freight" HeaderText="Freight"/>
    </Columns>
    </asp:GridView>
    </div>
    </td></tr>
    </ItemTemplate>
    </asp:TemplateField>
    </Columns>
   </asp:GridView>
    
  <asp:SqlDataSource ID="SqlDataSource1" runat="server" 
   ConnectionString="<%$ ConnectionStrings:ConnectionString %>" 
   SelectCommand="SELECT [CustomerID], [CompanyName] 
                FROM [Customers]">
   </asp:SqlDataSource>

Add following JavaScript in head section of page.
<script type="text/javascript">
function collapseExpand(obj)
{
  var gvObject = document.getElementById(obj);
  var imageID = document.getElementById('image' + obj);
 
 if (gvObject.style.display == "none")
      {
         gvObject.style.display = "inline";
         imageID.src = "minus.png";
      }
  else
     {
         gvObject.style.display = "none";
         imageID.src = "plus.png";
     }
}
</script>
Write following code in RowDataBound Event of parent Grid to populate nested gridview.

C#
protected void gvMaster_RowDataBound(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.DataRow)
        {
 string customerID = Convert.ToString(DataBinder.Eval(e.Row.DataItem, "CustomerID"));
            GridView gvChild = (GridView)e.Row.FindControl("nestedGridView");
            SqlDataSource gvChildSource = new SqlDataSource();
            gvChildSource.ConnectionString = ConfigurationManager.ConnectionStrings["ConnectionString"].ConnectionString;
            gvChildSource.SelectCommand = "SELECT [OrderID], [OrderDate],[Freight] FROM [Orders] WHERE [CustomerID] = '" + customerID + "'";
            gvChild.DataSource = gvChildSource;
            gvChild.DataBind();     }
}

VB.NET
Protected Sub gvMaster_RowDataBound(sender As Object, e As GridViewRowEventArgs)
 If e.Row.RowType = DataControlRowType.DataRow Then
  Dim customerID As String = Convert.ToString(DataBinder.Eval(e.Row.DataItem, "CustomerID"))
  Dim gvChild As GridView = DirectCast(e.Row.FindControl("nestedGridView"), GridView)
  Dim gvChildSource As New SqlDataSource()
  gvChildSource.ConnectionString = ConfigurationManager.ConnectionStrings("ConnectionString").ConnectionString
  gvChildSource.SelectCommand = "SELECT [OrderID], [OrderDate],[Freight] FROM [Orders] WHERE [CustomerID] = '" + customerID + "'"
  gvChild.DataSource = gvChildSource
  gvChild.DataBind()
 End If
End Sub

I hope this will be helpful for you. I would like to have any feedback from you. 
Your valuable feedback, question, or comments about this article are always welcome.

Comments

Popular posts from this blog

ASP.NET e-Commerce website GridView with Product Listing

Introduction : E-Commerce web applications are everywhere these days, and many share a common set of functionality. In this article, I will show how to use the GridView and ListView controls to build a powerful product page with many of the features found on today's e-commerce sites. We'll build a bicycle store product grid using some free clip art bicycle images. The example files are user controls which can be easily added to a page. We're only using three images here to keep the size of the sample application small. In previously I was explained about  Sending Email from Asp.net With Dynamic Content  ,  How To Export gridview data to Excel/PDF , CSV Formates in asp.net C#  , How to print Specific Area in asp.net web page How To- Search records or data in gridview using jQuery  . A shopping cart application would require to display the products in a multi column grid, rather than a straight down list or a table. The each item in a product grid would have

How to hide url parameters in asp.net

There are different ways to Hide the URL in asp.net , you can choose any one from bellow options . Previously I was Explained about the  Difference between Convert.tostring and .tostring() method Example  ,   Reasons to use Twitter Bootstrap , How to Register AJAX toolkit in web.config file in asp.net a) Using Post Method b) Using Of Session . c) URL Encoding & decoding process . d) Using Server.Transfer() instead of Response.Redirect() method (1)Use a form and POST the information. This might require additional code in source pages, but should not require logic changes in the target pages (merely change Request.QueryString to Request.Form). While POST is not impossible to muck with, it's certainly less appealing than playing with QueryString parameters. (2)Use session variables to carry information from page to page. This is likely a more substantial effort compared to (1), because you will need to take session variable checking into account (e.g. the

Asp.Net AjaxFileUpload Control With Drag Drop And Progress Bar

This Example explains how to use AjaxFileUpload Control With Drag Drop And Progress Bar Functionality In Asp.Net 2.0 3.5 4.0 C# And VB.NET. Previous Post  I was Explained about the   jQuery - Allow Alphanumeric (Alphabets & Numbers) Characters in Textbox using JavaScript  ,  Fileupload show selected file in label when file selected  ,  Check for file size with JavaScript before uploading  . May 2012 release of AjaxControlToolkit includes a new AjaxFileUpload Control  which supports Multiple File Upload, Progress Bar and Drag And Drop functionality. These new features are supported by Google Chrome version 16+, Firefox 8+ , Safari 5+ and Internet explorer 10 + , IE9 or earlier does not support this feature. To start with it, download and put latest AjaxControlToolkit.dll in Bin folder of application, Place ToolkitScriptManager  and AjaxFileUpload on the page. HTML SOURCE < asp:ToolkitScriptManager ID ="ToolkitScriptManager1" runat =&quo